Saltare alla navigazione principale

Archiviazione Personalizzata

Capgo supporta soluzioni di archiviazione personalizzate per i pacchetti del tuo'applicazione, consentendoti di ospitare le tue aggiornamenti sul tuo proprio infrastruttura o sui servizi di archiviazione di terze parti. Ciò è particolarmente utile per le organizzazioni con specifiche esigenze di sicurezza, necessità di conformità o infrastrutture di archiviazione esistenti.

L'archiviazione personalizzata in Capgo funziona caricando il tuo pacchetto in un luogo esterno e fornendo a Capgo l'URL per accedervi. Il Capgo SDK scaricherà poi gli aggiornamenti direttamente dalla tua posizione di archiviazione personalizzata anziché da Capgo’s archiviazione cloud di default.

Il modo più semplice per utilizzare un storage personalizzato è caricare il tuo pacchetto su qualsiasi URL accessibile al pubblico e fornire quella URL a Capgo.

Finestra del terminale
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip

Questo comando dice a Capgo di riferirsi al pacchetto all'indirizzo URL specificato invece di caricarlo su Capgo’s archiviazione cloud.

Per un archivio esterno sicuro, puoi crittografare il tuo bundle e fornire le chiavi di decrittografia:

Finestra del terminale
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip --iv-session-key YOUR_IV_SESSION_KEY

Capgo fornisce un supporto integrato per Amazon S3 e servizi di archiviazione S3 compatibili. Il CLI può caricare automaticamente il tuo bundle su S3 e configurare Capgo per utilizzare l'URL S3.

Finestra del terminale
npx @capgo/cli@latest bundle upload \
--s3-region us-east-1 \
--s3-apikey YOUR_ACCESS_KEY \
--s3-apisecret YOUR_SECRET_KEY \
--s3-bucket-name your-bucket-name

Per servizi S3 compatibili o endpoint personalizzati:

Finestra del terminale
npx @capgo/cli@latest bundle upload \
--s3-region us-east-1 \
--s3-apikey YOUR_ACCESS_KEY \
--s3-apisecret YOUR_SECRET_KEY \
--s3-endpoint https://s3.your-provider.com \
--s3-bucket-name your-bucket-name \
--s3-port 443 \
--no-s3-ssl # Only if your endpoint doesn't support SSL
ParametroDescrizioneRichiesto
--s3-regionRegione AWS per il tuo bucket S3
--s3-apikeyID chiave di accesso S3
--s3-apisecret__CAPGO_KEEP_0__
--s3-bucket-nameNome del tuo bucket S3
--s3-endpointURL personalizzato dell'endpoint S3No
--s3-port__CAPGO_KEEP_1__No
--no-s3-sslDisabilita SSL per l'upload S3No

Quando si utilizza un archivio di storage personalizzato, soprattutto con crittografia, è necessario preparare correttamente i propri pacchetti. Ciò comporta la creazione di un file zip e la crittografia facoltativa.

In primo luogo, crea un file zip del pacchetto dell'applicazione:

Finestra del terminale
npx @capgo/cli@latest bundle zip com.example.app --path ./dist

Il comando zip restituirà il checksum del file zip. Puoi utilizzare questo checksum per crittografare il file zip se necessario. Utilizza l' --json Opzioni del comando Zip

Sezione intitolata “Opzioni del comando Zip”

Finestra del terminale
Opzioni del comando Zip
npx @capgo/cli@latest bundle zip [appId] \
--path ./dist \
--bundle 1.2.3 \
--name myapp-v1.2.3 \
--json \
--no-code-check \
--key-v2 \
--package-json ../../package.json,./package.json
OpzioneDescrizione
--pathPercorso del folder da archiviare (predefinito a webDir da capacitor.config)
--bundleNumero di versione del bundle per denominare il file zip
--nameNome personalizzato per il file zip
--jsonRisultati di output in formato JSON (inclusa checksum)
--no-code-checkSaltare la verifica della chiamata a notifyAppReady() e dell'indice del file
--key-v2Utilizzare l'encryption v2
--package-jsonPercorsi dei file package.json per i monorepos (separati da virgole)

Per una maggiore sicurezza, crittografate il vostro bundle zip prima di caricarlo:

Finestra del terminale
# Using default local key
npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM
# Using custom key file
npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key ./path/to/.capgo_key_v2
# Using key data directly
npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key-data "PRIVATE_KEY_CONTENT"

Il CHECKSUM Il parametro è richiesto e dovrebbe essere il checksum del vostro file zip. Potete ottenere il checksum dal comando zip (utilizzate --json l'opzione per l'output strutturato).

Di default, il comando di crittografia utilizzerà la vostra chiave di firma privata locale. Potete specificare una chiave personalizzata utilizzando --key o --key-data le opzioni.

Il comando di crittografia restituirà il ivSessionKey necessario per il caricamento o la decrittografia.

OpzioneDescrizione
zipPathPercorso del file zip da crittografare (obbligatorio)
checksumChecksum del file zip (obbligatorio) - ottienilo dal comando zip
--keyPercorso personalizzato per la chiave di firma privata (facoltativo, utilizza la chiave locale per impostazione predefinita)
--key-dataDati della chiave di firma privata direttamente (facoltativo)
--jsonRisultati di output in formato JSON
  1. Costruisci la tua app:

    Finestra del terminale
    npm run build
  2. Crea un bundle zip:

    Finestra del terminale
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --bundle 1.2.3

    Nota il checksum restituito da questo comando.

  3. Crittografa il bundle:

    Finestra del terminale
    npx @capgo/cli@latest bundle encrypt ./com.example.app-1.2.3.zip CHECKSUM_FROM_STEP_2

    Nota il ivSessionKey dalla finestra di output.

  4. Carica nel tuo storage: Carica il file zip crittografato nel tuo servizio di hosting.

  5. Registra con Capgo:

    Finestra del terminale
    npx @capgo/cli@latest bundle upload \
    --external https://your-cdn.com/bundles/com.example.app-1.2.3.zip \
    --iv-session-key IV_SESSION_KEY_FROM_STEP_3
  1. Costruisci l'applicazione:

    Finestra del terminale
    npm run build
  2. Carica direttamente su S3:

    Finestra del terminale
    npx @capgo/cli@latest bundle upload \
    --s3-region us-west-2 \
    --s3-apikey YOUR_ACCESS_KEY \
    --s3-apisecret YOUR_SECRET_KEY \
    --s3-bucket-name your-app-bundles \
    --channel Production
  1. Costruisci e zip:

    Finestra del terminale
    npm run build
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2
  2. Crittografa il bundle:

    Finestra del terminale
    npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM
  3. Carica su S3 con crittografia:

    Finestra del terminale
    npx @capgo/cli@latest bundle upload \
    --s3-region us-west-2 \
    --s3-apikey YOUR_ACCESS_KEY \
    --s3-apisecret YOUR_SECRET_KEY \
    --s3-bucket-name your-app-bundles \
    --iv-session-key IV_SESSION_KEY_FROM_STEP_2 \
    --channel Production

Quando si utilizza un archivio di storage personalizzato, considera queste pratiche di sicurezza:

  • Assicurati che le tue URL di archiviazione siano accessibili agli utenti del tuo'applicazione, ma non siano scopribili pubblicamente
  • Utilizza URL firmati o autenticazione basata su token quando possibile
  • Implementare i header CORS corretti per le app basate su web
  • Crittografare sempre i bundle sensibili utilizzando gli strumenti di crittografia Capgo
  • Mantieni le chiavi di crittografia in modo sicuro e rotale regolarmente
  • Utilizza HTTPS per tutte le URL dei bundle (richiesto per le app mobili e Electron)
  • Monitorare i log di accesso per rilevare modelli di download anomali
  • Configura gli avvisi per i download dei bundle falliti
  • Auditare regolarmente le autorizzazioni di archiviazione

Il bundle non si sta scaricando:

  • Verifica che l'URL sia accessibile pubblicamente e utilizzino HTTPS (richiesto per le app mobili e Electron)
  • Controlla i header CORS per le app web
  • Assicurati che il formato del bundle sia corretto

Errori di crittografia:

  • Verifica che il valore della proprietà ivSessionKey corrisponda al bundle crittografato
  • Controlla che il bundle sia stato crittografato con la chiave corretta
  • Assicurati che venga utilizzata la crittografia v2 per i nuovi bundle

Fallimenti di caricamento S3:

  • Verifica le tue credenziali e le autorizzazioni S3
  • Controlla le politiche del contenitore e la configurazione CORS
  • Assicurati che la regione specificata sia corretta

Verifica lo stato del pacchetto:

Finestra del terminale
npx @capgo/cli@latest app debug

Verifica l'integrità del pacchetto:

Finestra del terminale
npx @capgo/cli@latest bundle list