Archiviazione Personalizzata
Copia un prompt di configurazione con le istruzioni di installazione e la guida markdown completa per questo plugin.
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.
Panoramica
Sottosezione intitolata “Panoramica”L'archiviazione personalizzata in Capgo funziona caricando il tuo pacchetto in un'ubicazione esterna e fornendo a Capgo l'URL per accedervi. Il Capgo SDK scaricherà poi gli aggiornamenti direttamente dalla tua ubicazione di archiviazione personalizzata anziché da Capgo’s archiviazione cloud di default.
Carica URL esterna
Sottosezione intitolata “Carica URL esterna”La modalità più semplice per utilizzare lo storage personalizzato consiste nell'upload del proprio bundle su qualsiasi URL accessibile pubblicamente e fornire quella URL a Capgo.
Carica URL esterna base
Sottosezione intitolata “Carica URL esterna base”npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zipQuesto comando dice a Capgo di riferirsi al bundle alla URL specificata anziché caricarlo su Capgo’s archiviazione cloud.
Con crittografia
Sottosezione intitolata “Con crittografia”Per uno storage esterno sicuro, puoi crittografare il tuo bundle e fornire le chiavi di decrittografia:
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip --iv-session-key YOUR_IV_SESSION_KEYIntegrazione S3
Sezione intitolata “Integrazione S3”Capgo fornisce un supporto integrato per Amazon S3 e servizi di archiviazione S3 compatibili. Il CLI può caricare automaticamente il bundle su S3 e configurare Capgo per utilizzare l'URL 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-nameConfigurazione 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 SSLParametri di configurazione S3
Sezione intitolata “Parametri di configurazione S3”| Parametro | Descrizione | Richiesto |
|---|---|---|
--s3-region | Regione AWS per il tuo bucket S3 | Sì |
--s3-apikey | ID chiave di accesso S3 | Sì |
--s3-apisecret | Chiave segreta di accesso S3 | Sì |
--s3-bucket-name | Nome del tuo bucket S3 | Sì |
--s3-endpoint | URL personalizzata dell'endpoint S3 | No |
--s3-port | Porta per l'endpoint S3 | No |
--no-s3-ssl | Disabilita SSL per l'upload S3 | No |
Preparazione e crittografia del pacchetto
Sezione intitolata “Preparazione e crittografia del pacchetto”Quando si utilizza un archiviazione personalizzata, soprattutto con la crittografia, è necessario preparare i pacchetti in modo appropriato. Ciò comporta la creazione di un file zip e, facoltativamente, la crittografia.
Passo 1: Crea un pacchetto zip
Sezione intitolata “Passo 1: Crea un bundle ZIP”Innanzitutto, crea un file ZIP del tuo bundle dell'applicazione:
npx @capgo/cli@latest bundle zip com.example.app --path ./distIl comando ZIP restituirà il checksum del file ZIP. Puoi utilizzare questo checksum per cifrare il file ZIP se necessario. Utilizza l' --json opzione per ottenere un output strutturato che include il checksum.
Opzioni del comando ZIP
Sezione intitolata “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| Opzione | Descrizione |
|---|---|
--path | Percorso del folder da archiviare (predefinito da webDir da capacitor.config) |
--bundle | Numero di versione del bundle per denominare il file zip |
--name | Nome personalizzato per il file zip |
--json | Risultati di output in formato JSON (incluso checksum) |
--no-code-check | Saltare la verifica della chiamata a notifyAppReady() e dell'indice del file |
--key-v2 | Usare l'encryption v2 |
--package-json | Percorso dei file package.json per i monorepos (separati da virgole) |
Passo 2: Criptare il Bundle (Facoltativo)
Sezione intitolata “Passo 2: Criptare il Bundle (Facoltativo)”Per una maggiore sicurezza, criptare il tuo bundle zip prima di caricarlo:
# Using default local keynpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM
# Using custom key filenpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key ./path/to/.capgo_key_v2
# Using key data directlynpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key-data "PRIVATE_KEY_CONTENT"The parameter is required and should be the checksum of your zip file. You can get the checksum from the zip command output (use the CHECKSUM option for structured output). --json Di default, il comando di crittografia utilizzerà la tua chiave privata di firma locale. Puoi specificare una chiave personalizzata utilizzando il
o --key opzione. --key-data Il comando di crittografia restituirà il
necessario per l'upload o la decrittografia. ivSessionKey Opzioni del comando di crittografia
Sottosezione intitolata “Opzioni del comando di crittografia”
Opzione| Descrizione | Option |
|---|---|
zipPath | Percorso del file zip da cifrare (obbligatorio) |
checksum | Checksum del file zip (obbligatorio) - ottienilo con il comando zip |
--key | Percorso personalizzato per la chiave di firma privata (facoltativo, utilizza la chiave locale per impostazione predefinita) |
--key-data | Dati della chiave di firma privata direttamente (facoltativo) |
--json | Risultati di output in formato JSON |
Esempi di Flussi di Lavoro Completi
Sottosezione intitolata “Esempi di Flussi di Lavoro Completi”Esempio 1: URL esterna con crittografia
Sottosezione intitolata “Esempio 1: URL esterna con crittografia”-
Costruisci l'applicazione:
Fermata dei comandi npm run build -
Crea un bundle zip:
Fermata dei comandi npx @capgo/cli@latest bundle zip com.example.app --path ./dist --bundle 1.2.3Nota il checksum restituito da questo comando.
-
Crittografa il bundle:
Fermata dei comandi npx @capgo/cli@latest bundle encrypt ./com.example.app-1.2.3.zip CHECKSUM_FROM_STEP_2Nota il
ivSessionKeydalla output. -
Carica sul tuo storage: Carica il file zip cifrato sul tuo servizio di hosting.
-
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
Esempio 2: Carica diretta S3
Sezione intitolata “Esempio 2: Carica diretta S3”-
Costruisci il tuo app:
Finestra del terminale npm run build -
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
Esempio 3: S3 con crittografia
Sezione intitolata “Esempio 3: S3 con crittografia”-
Costruisci e zip:
Finestra del terminale npm run buildnpx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2 -
Crittografa il bundle:
Finestra del terminale npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM -
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
Considerazioni di sicurezza
Sezione intitolata “Considerazioni di sicurezza”Quando si utilizza un archivio personalizzato, considera queste pratiche di sicurezza:
Controllo degli accessi
Sezione intitolata “Controllo degli accessi”- Assicurati che le tue URL di archiviazione siano accessibili agli utenti del tuo app ma non scopribili pubblicamente
- Utilizza URL firmati o autenticazione basata su token quando possibile
- Implementa i header CORS appropriati per gli app web
Crittografia
Sezione intitolata “Crittografia”- Utilizza sempre gli strumenti di crittografia Capgo per cifrare i pacchetti sensibili
- Conserva le chiavi di crittografia in modo sicuro e rinnovale regolarmente
- Utilizza HTTPS per tutte le URL dei pacchetti (richiesto per le app mobili e Electron)
Monitoraggio
Sezione intitolata “Monitoraggio”- Monitora i log di accesso per rilevare modelli di download anomali
- Configura gli avvisi per i download dei pacchetti falliti
- Auditare regolarmente le autorizzazioni di archiviazione
Risoluzione dei problemi
Sezione intitolata “Risoluzione dei problemi”Problemi comuni
Sezione intitolata “Problemi comuni”Il pacchetto 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 pacchetto sia corretto
Errori di crittografia:
- Verifica che si tratta del pacchetto crittografato
ivSessionKeyControlla che il pacchetto sia stato crittografato con la chiave corretta - Assicurati che venga utilizzata la crittografia v2 per i nuovi pacchetti
- Fallimenti nell'upload su S3:
Verifica le tue credenziali e le autorizzazioni S3
- Controlla le politiche del bucket e la configurazione CORS
- __CAPGO_KEEP_0__
- Assicurati che la regione specificata sia corretta
Comandi di debug
Sezione intitolata “Comandi di debug”Verifica lo stato del pacchetto:
npx @capgo/cli@latest app debugVerifica l'integrità del pacchetto:
npx @capgo/cli@latest bundle listPassaggi successivi
Sezione intitolata “Passaggi successivi”- Impara su Canali per gestire diversi ambienti di distribuzione
- Esplora Comportamento di Aggiornamento per personalizzare come vengono applicate le aggiornamenti
- Configura Integrazione CI/CD per automatizzare il tuo flusso di lavoro di archiviazione personalizzato
Continua da Archiviazione Personalizzata
Se stai utilizzandoArchiviazione Personalizzata __CAPGO_KEEP_0__ per pianificare la sicurezza e la conformità, connettilo con Crittografia per il dettaglio di implementazione in Crittografia, Conformità per il dettaglio di implementazione in Conformità, Capgo Scansionatore di Sicurezza per il workflow del prodotto in Capgo Scansionatore di Sicurezza, Capgo Sicurezza per il workflow del prodotto in Capgo Sicurezza, e Capgo Centro di Trust per il workflow del prodotto in Capgo Centro di Trust.