Passer à la navigation

Stockage personnalisé

Capgo prend en charge les solutions de stockage personnalisées pour vos ensembles de fichiers d'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 bundle vers un emplacement externe et en fournissant à Capgo l'URL pour y accéder. Le Capgo SDK téléchargera ensuite les mises à jour directement à partir de votre emplacement de stockage personnalisé au lieu du stockage cloud par défaut de Capgo.

La manière la plus simple d'utiliser le stockage personnalisé est de télécharger votre bundle vers 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 bundle à l'adresse URL spécifiée au lieu de le télécharger 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 propose une prise en charge intégrée 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 des 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 dossier S3Oui
--s3-apikeyID de clé d'accès S3Oui
--s3-apisecretClé secrète S3Oui
--s3-bucket-nameNom de votre dossier S3Oui
--s3-endpointURL de l'endpoint S3 personnaliséNon
--s3-portPort pour l'endpoint S3Non
--no-s3-sslDésactiver SSL pour l'upload S3Non

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

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 renverra 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”

Fenêtre de terminal
Copier dans le presse-papier
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
DescriptionChemin du dossier à zipper (par défaut webDir de __CAPGO_KEEP_0__.config)
--pathPath to the folder to zip (defaults to webDir from capacitor.config)
--bundleNom personnalisé pour le fichier zip
--nameUtilisez l'option pour obtenir un résultat structuré incluant le checksum.
--jsonRésultats d'output sous format JSON (inclus checksum)
--no-code-checkIgnorer la vérification de l'appel à notifyAppReady() et du fichier index
--key-v2Utiliser l'encryption v2
--package-jsonChemins vers les fichiers package.json pour les monorepos (séparés par des virgules)

Pour une sécurité renforcée, chiffrer votre zip bundle 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 sortie de la commande zip (utiliser --json option pour sortie structurée)

Par défaut, la commande de chiffrement utilisera votre clé privée de signature locale. Vous pouvez spécifier une clé personnalisée à l'aide de --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é privée de signature (facultatif, utilise la clé locale par défaut)
--key-dataDonnées de clé de signature privée directement (facultatif)
--jsonRésultats d'output en format 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 : 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 chiffrement :

    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

Lors de l'utilisation de stockages personnalisés, prenez en compte ces meilleures pratiques de sécurité :

  • Assurez-vous que vos URL de stockage soient accessibles à vos utilisateurs d'application mais pas découvrables publiquement
  • Utilisez des URL signées ou une 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 de bundle (obligatoire pour les applications mobiles et Electron)
  • Surveillez les journaux d'accès pour détecter des modèles de téléchargement inhabituels
  • Configurez des alertes pour les téléchargements de bundles échoués
  • Effectuez régulièrement des audits de vos permissions de stockage

Le bundle ne télécharge pas :

  • Vérifiez que l'URL est accessible publiquement 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 d'encryption :

  • Vérifiez que le ivSessionKey correspond au bundle chiffré
  • Vérifiez que le bundle a été chiffré avec la bonne clé
  • Assurez-vous que l'encryption v2 est utilisé pour les nouveaux bundles

Échecs d'upload S3 :

  • Vérifiez vos identifiants et permissions 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 du paquet :

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

Vérifiez l'intégrité du paquet :

Fenêtre de terminal
npx @capgo/cli@latest bundle list
  • En savoir plus sur Canaux pour gérer différents environnements de déploiement
  • Explorez 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é

Continuez de la section Stockage personnalisé

Si vous utilisez

Stockage personnalisé pour planifier la sécurité et la conformité, connectez-le avec Chiffrement pour les détails d'implémentation dans Chiffrement, Si vous utilisez Custom Storage pour planifier la sécurité et la conformité, connectez-le avec Chiffrement, pour les détails d'implémentation dans Chiffrement, Conformité pour le détail d'implémentation dans Conformité, Capgo Scanner de Sécurité pour le flux de travail du produit dans Capgo Scanner de Sécurité, Capgo Sécurité pour le flux de travail du produit dans Capgo Sécurité, et Capgo Centre de Confiance pour le flux de travail du produit dans Capgo Centre de Confiance.