Saltare al contenuto

Archiviazione Personalizzata

Capgo supporta soluzioni di archiviazione personalizzate per i pacchetti dell'applicazione, consentendo di ospitare gli aggiornamenti sul 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 infrastruttura di archiviazione esistente.

Il storage personalizzato in Capgo funziona caricando il tuo bundle in un'ubicazione esterna e fornendo a Capgo l'URL per accedervi. Il Capgo SDK scaricherà quindi le aggiornamenti direttamente dalla tua ubicazione di storage personalizzato al posto della storage cloud di Capgo per impostazione predefinita.

Il modo più semplice per utilizzare il storage personalizzato è caricando il tuo bundle in qualsiasi URL accessibile pubblicamente e fornendo quell'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 al URL specificato invece di caricarlo nel cloud storage di Capgo’s.

Per un storage esterno sicuro, puoi crittografare il tuo pacchetto 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 provides built-in support for Amazon S3 and S3-compatible storage services. The CLI can automatically upload your bundle to S3 and configure Capgo to use the S3 URL.

Le __CAPGO_KEEP_1__ possono caricare automaticamente il bundle su S3 e configurare __CAPGO_KEEP_2__ per utilizzare l'URL di S3.

Opzioni di caricamento S3
Sezione intitolata “Opzioni di caricamento S3”
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

Copia negli appunti

Configurazione S3 completa

Sezione intitolata “Configurazione S3 completa”

Per servizi S3 compatibili o endpoint personalizzati:
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
ParametroDescrizioneObbligatorio
--s3-regionRegione AWS per il tuo bucket S3
--s3-apikeyID chiave di accesso S3
--s3-apisecretChiave segreta S3
--s3-bucket-nameNome del tuo bucket S3
--s3-endpointURL personalizzato del endpoint S3No
--s3-portPorta per endpoint S3No
--no-s3-sslDisabilita SSL per l'upload S3No

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

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 cifrare il file zip se necessario. Utilizza l'"opzione" per ottenere un output strutturato incluso il checksum. --json Opzioni del comando Zip

Sezione intitolata “Opzioni del comando Zip”

Finestra del terminale
Copia negli appunti
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
DescrizionePercorso del folder da zip (predefinito a webDir da __CAPGO_KEEP_0__.config)
--pathPath to the folder to zip (defaults to webDir from capacitor.config)
--bundleNome personalizzato per il file zip
--nameCopia negli appunti
--jsonI risultati vengono restituiti in formato JSON (incluso checksum)
--no-code-checkSaltare la verifica della chiamata a notifyAppReady() e dell'indice del file
--key-v2Usare l'encryption v2
--package-jsonPercorso dei file package.json per i monorepos (separati da virgole)

Per una maggiore sicurezza, criptare il tuo 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 tuo file zip. Puoi ottenere il checksum dal comando zip (utilizza --json l'opzione per l'output strutturato)

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

Il comando di cifratura restituirà i ivSessionKey necessari per l'upload o la decifrazione.

NomeDescrizione
zipPathPercorso del file zip da cifrare (obbligatorio)
checksumChecksum del file zip (obbligatorio) - ottienilo dal comando zip
--keyPercorso personalizzato per la chiave di firma privata (facoltativo, utilizza la chiave locale di default)
--key-dataDati della chiave di firma privata vengono inviati direttamente (facoltativo)
--jsonI risultati vengono visualizzati in formato JSON
  1. Costruisci il tuo 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 sul tuo storage: Carica il file zip crittografato sul 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 il tuo app:

    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:

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

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

    Fermata del terminal
    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 archiviazione personalizzata, considera queste pratiche di sicurezza migliori:

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

Download del bundle non avviene:

  • Verifica che l'URL sia accessibile pubblicamente e utilizza 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 il ivSessionKey corrisponde 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 nell'upload su S3:

  • Verifica le tue credenziali e autorizzazioni S3
  • Controlla le politiche del bucket 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
  • Scopri Canali per gestire diversi ambienti di distribuzione
  • Esplora Aggiorna il comportamento per personalizzare come vengono applicate le aggiornamenti
  • Imposta Integrazione CI/CD per automatizzare il tuo flusso di lavoro di archiviazione personalizzato

Continua da Archiviazione personalizzata

Se stai utilizzando

Archiviazione personalizzata per pianificare la sicurezza e la conformità, connettilo con Critturazione per i dettagli di implementazione in Critturazione, If you are using Conformità per il dettaglio di implementazione in Conformità, Capgo Scansionatore di Sicurezza per il flusso di lavoro del prodotto in Capgo Scansionatore di Sicurezza, Capgo Sicurezza per il flusso di lavoro del prodotto in Capgo Sicurezza, e Capgo Centro di Trust per il flusso di lavoro del prodotto in Capgo Centro di Trust.