Aller directement au contenu

Stockage personnalisé

Capgo prend en charge les solutions de stockage personnalisées pour vos ensembles de l'application, vous permettant de héberger vos mises à jour sur votre propre infrastructure ou sur des services de stockage tiers. Cela est particulièrement utile pour les organisations ayant des exigences de sécurité spécifiques, des besoins de conformité ou une infrastructure de stockage existante.

Le stockage personnalisé dans Capgo fonctionne en téléchargeant votre ensemble sur un emplacement externe et en fournissant à Capgo l'URL pour y accéder. Les Capgo SDK téléchargeront ensuite les mises à jour directement de votre emplacement de stockage personnalisé au lieu de l'infrastructure de stockage par défaut de Capgo.

La manière la plus simple d'utiliser un stockage personnalisé est d'uploader votre paquet sur n'importe quelle URL accessible au public et de fournir cette URL à Capgo.

Fenêtre de terminal
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip

Cette commande indique à Capgo de référencer le paquet à l'URL spécifiée au lieu de l'uploader dans le stockage cloud de Capgo.

Pour un stockage externe sécurisé, vous pouvez chiffrer votre bundle et fournir les clés de déchiffrement :

Fenêtre de terminal
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip --iv-session-key YOUR_IV_SESSION_KEY

Capgo fournit un support intégré pour Amazon S3 et les services de stockage S3 compatibles. Le CLI peut télécharger automatiquement votre bundle sur S3 et configurer Capgo pour utiliser l'URL S3.

Fenêtre de terminal
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

Pour les services S3 compatibles ou les points de terminaison personnalisés :

Fenêtre de terminal
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
ParamètreDescriptionObligatoire
--s3-regionRégion AWS pour votre bac S3Oui
--s3-apikey__CAPGO_KEEP_0__ ID de clé d'accès S3Oui
--s3-apisecret__CAPGO_KEEP_1__ secret d'accès S3Oui
--s3-bucket-name__CAPGO_KEEP_2__ Nom de votre bac S3Oui
--s3-endpoint__CAPGO_KEEP_3__ URL de l'endpoint S3 personnaliséNon
--s3-port__CAPGO_KEEP_4__ Port de l'endpoint S3Non
--no-s3-ssl__CAPGO_KEEP_5__ Désactiver SSL pour l'upload S3Non

Lorsque vous utilisez un stockage personnalisé, en particulier avec le chiffrement, vous devez préparer vos bundles correctement. Cela implique la création d'un fichier zip et le chiffrement facultatif.

Créez d'abord un fichier zip de votre bundle d'application :

Fenêtre de terminal
npx @capgo/cli@latest bundle zip com.example.app --path ./dist

La commande zip retournera le checksum du fichier zip. Vous pouvez utiliser ce checksum pour chiffrer le fichier zip si nécessaire. Utilisez l'option pour obtenir un résultat structuré incluant le checksum. --json Options de la commande Zip

Section intitulée “Options de la commande Zip”

__CAPGO_KEEP_0__
Fenêtre de terminal
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
OptionDescription
--pathChemin du dossier à zipper (par défaut webDir de capacitor.config)
--bundleNuméro de version du bundle pour nommer le fichier zip
--nameNom personnalisé pour le fichier zip
--jsonRésultats d'output en format JSON (inclut le checksum)
--no-code-checkIgnorer la vérification de la fonction notifyAppReady() et du fichier index
--key-v2Utiliser l'encryption v2
--package-jsonChemins des fichiers package.json pour les monorepos (séparés par des virgules)

Étape 2 : Chiffrer le Bundle (Optionnel)

Étape 2 : Chiffrer le Bundle (Facultatif)

Pour une sécurité renforcée, chiffrer votre bundle zip avant de l'uploader :

Fenêtre de terminal
# 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"

Le CHECKSUM ce paramètre est obligatoire et doit être le checksum de votre fichier zip. Vous pouvez obtenir le checksum à partir de la commande zip (utilisez --json option pour un affichage structuré).

Par défaut, la commande de chiffrement utilisera votre clé privée de signature locale. Vous pouvez spécifier une clé personnalisée en utilisant les --key ou --key-data options.

La commande de chiffrement retournera les ivSessionKey nécessaires pour l'upload ou la déchiffrement.

OptionDescription
zipPathChemin du fichier zip à chiffrer (obligatoire)
checksumChecksum du fichier zip (obligatoire) - obtenez-le à partir de la commande zip
--keyChemin personnalisé pour la clé de signature privée (facultatif, utilise la clé locale par défaut)
--key-dataDonnées de la clé de signature privée directement (facultatif)
--jsonAfficher les résultats sous forme de JSON
  1. Construire votre application :

    Fenêtre de terminal
    npm run build
  2. Créer un bundle zip :

    Fenêtre de terminal
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --bundle 1.2.3

    Notez le checksum retourné par cette commande.

  3. Chiffrer le bundle :

    Fenêtre de terminal
    npx @capgo/cli@latest bundle encrypt ./com.example.app-1.2.3.zip CHECKSUM_FROM_STEP_2

    Notez le ivSessionKey à partir de l'output.

  4. Télécharger sur votre stockage : Télécharger le fichier zip chiffré sur votre service de hébergement.

  5. S'inscrire avec Capgo:

    Fenêtre de terminal
    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. Construire votre application :

    Fenêtre de terminal
    npm run build
  2. Télécharger directement sur S3 :

    Fenêtre de 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 \
    --channel Production
  1. Construire et compresser :

    Fenêtre de terminal
    npm run build
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2
  2. Chiffrer le bundle :

    Fenêtre de terminal
    npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM
  3. Charger sur S3 avec chiffrage :

    Fenêtre de 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

Lorsque vous utilisez un stockage personnalisé, considérez ces bonnes pratiques de sécurité :

  • Assurez-vous que vos URL de stockage soient accessibles à vos utilisateurs d'application mais pas découvrables publiquement
  • Utilisez les URL signées ou l'authentification basée sur des jetons lorsque cela est possible
  • Implémentez les en-têtes CORS appropriés pour les applications web
  • Chiffrez toujours les bundles sensibles à l'aide des outils de chiffrement Capgo
  • Stockez les clés de chiffrement de manière sécurisée et les renouvelez régulièrement
  • Utilisez HTTPS pour toutes les URL des bundles (obligatoire pour les applications mobiles et Electron)
  • Surveillez les journaux d'accès pour détecter les modèles de téléchargement inhabituels
  • Configurez des alertes pour les téléchargements de bundles échoués
  • Auditez régulièrement vos permissions de stockage

Le bundle ne télécharge pas :

  • Vérifiez que l'URL est accessible au public et utilise HTTPS (obligatoire pour les applications mobiles et Electron)
  • Vérifiez les en-têtes CORS pour les applications web
  • Assurez-vous que le format du bundle est correct

Erreurs de chiffrement :

  • Vérifiez que le ivSessionKey correspond au bundle chiffré
  • Vérifiez que le bundle a été chiffré avec la bonne clé
  • Utilisez l'encryption v2 pour les nouveaux ensembles

Échecs d'upload S3 :

  • Vérifiez vos identifiants et vos autorisations S3
  • Vérifiez les politiques de la boîte et la configuration CORS
  • Assurez-vous que la région spécifiée est correcte

Vérifiez l'état de l'ensemble :

Fenêtre de terminal
npx @capgo/cli@latest app debug

Vérifiez l'intégrité de l'ensemble :

Fenêtre de terminal
npx @capgo/cli@latest bundle list
  • En savoir plus sur Canaux pour gérer différents environnements de déploiement
  • Explorer Mise à jour du comportement pour personnaliser la façon dont les mises à jour sont appliquées
  • Configurer Intégration CI/CD pour automatiser votre flux de travail de stockage personnalisé