Bundles
Copiez un prompt de configuration avec les étapes d'installation et la guide markdown complet pour ce plugin.
Les paquets sont les packages de mise à jour centraux dans Capgo. Chaque paquet contient les actifs web (HTML, CSS, JS) qui composent le contenu de votre application. Les paquets API vous permettent de gérer ces packages de mise à jour, y compris la liste et la suppression.
Comprendre les paquets
Section intitulée “Comprendre les paquets”Un paquet représente une version spécifique du contenu web de votre application et comprend :
- Paquet (version): Numéro de version sémantique pour le bundle
- Coche de somme: Hash unique pour vérifier l'intégrité du bundle
- Informations de stockage: Détails sur où et comment le bundle est stocké
- Exigences natives: Exigences minimales de version de l'application native
- Métadonnées: Temps de création, propriété et autres informations de suivi
Création de bundle manuelle (Sans CLI)
Section intitulée “Création de bundle manuelle (Sans CLI)”Voici comment créer et télécharger des bundles manuellement sans utiliser le Capgo CLI :
Étape 1 : Construire votre application
Sous-titre « Étape 1 : Construire votre application »Tout d'abord, construisez les actifs web de votre application :
npm run buildÉtape 2 : Créer un fichier zip de bundle en utilisant les mêmes packages que Capgo CLI
Sous-titre « Étape 2 : Créer un fichier zip de bundle en utilisant les mêmes packages que Capgo CLI »Important: Utilisez les mêmes packages JavaScript exacts que Capgo CLI utilise internement pour garantir la compatibilité.
Installer les packages requis
Sous-titre « Installer les packages requis »npm install adm-zip @tomasklaen/checksumCréer un fichier Zip avec JavaScript (Même que Capgo CLI)
Section intitulée “Créer un fichier Zip avec JavaScript (Même que Capgo CLI)”Remarque : Dans les exemples ci-dessous, version se réfère au nom du fichier (version) utilisé par le API.
const fs = require('node:fs');const path = require('node:path');const os = require('node:os');const AdmZip = require('adm-zip');const { checksum: getChecksum } = require('@tomasklaen/checksum');
// Exact same implementation as Capgo CLIfunction zipFileUnix(filePath) { const zip = new AdmZip(); zip.addLocalFolder(filePath); return zip.toBuffer();}
async function zipFileWindows(filePath) { console.log('Zipping file windows mode'); const zip = new AdmZip();
const addToZip = (folderPath, zipPath) => { const items = fs.readdirSync(folderPath);
for (const item of items) { const itemPath = path.join(folderPath, item); const stats = fs.statSync(itemPath);
if (stats.isFile()) { const fileContent = fs.readFileSync(itemPath); zip.addFile(path.join(zipPath, item).split(path.sep).join('/'), fileContent); } else if (stats.isDirectory()) { addToZip(itemPath, path.join(zipPath, item)); } } };
addToZip(filePath, ''); return zip.toBuffer();}
// Main zipFile function (exact same logic as CLI)async function zipFile(filePath) { if (os.platform() === 'win32') { return zipFileWindows(filePath); } else { return zipFileUnix(filePath); }}
async function createBundle(inputPath, outputPath, version) { // Create zip using exact same method as Capgo CLI const zipped = await zipFile(inputPath);
// Write to file fs.writeFileSync(outputPath, zipped);
// Calculate checksum using exact same package as CLI const checksum = await getChecksum(zipped, 'sha256');
return { filename: path.basename(outputPath), version: version, size: zipped.length, checksum: checksum };}
// Usageasync function main() { try { const result = await createBundle('./dist', './my-app-1.2.3.zip', '1.2.3'); console.log('Bundle info:', JSON.stringify(result, null, 2)); } catch (error) { console.error('Error creating bundle:', error); }}
main();Étape 3 : Calculer la somme de contrôle SHA256 en utilisant le même package que CLI
Section intitulée “Étape 3 : Calculer la somme de contrôle SHA256 en utilisant le même package que CLI”const fs = require('node:fs');const { checksum: getChecksum } = require('@tomasklaen/checksum');
async function calculateChecksum(filePath) { const fileBuffer = fs.readFileSync(filePath); // Use exact same package and method as Capgo CLI const checksum = await getChecksum(fileBuffer, 'sha256'); return checksum;}
// Usageasync function main() { const checksum = await calculateChecksum('./my-app-1.2.3.zip'); console.log('Checksum:', checksum);}
main();Étape 4 : Télécharger le fichier dans votre stockage
Section intitulée “Étape 4 : Télécharger le fichier dans votre stockage”Charger votre fichier zip dans n'importe quel stockage accessible via le web :
# Example: Upload to your server via scpscp my-app-1.2.3.zip user@your-server.com:/var/www/bundles/
# Example: Upload to S3 using AWS CLIaws s3 cp my-app-1.2.3.zip s3://your-bucket/bundles/
# Example: Upload via curl to a custom endpointcurl -X POST https://your-storage-api.com/upload \ -H "Authorization: Bearer YOUR_TOKEN" \ -F "file=@my-app-1.2.3.zip"Important: Votre bundle doit être accessible au public via une URL HTTPS (aucune authentication requise). Les serveurs de Capgo doivent télécharger le bundle à partir de cette URL.
Exemples de URLs publiques valides :
https://your-storage.com/bundles/my-app-1.2.3.ziphttps://github.com/username/repo/releases/download/v1.2.3/bundle.ziphttps://cdn.jsdelivr.net/gh/username/repo@v1.2.3/dist.zip
Étape 5 : Enregistrer le Bundle avec Capgo API
Section intitulée « Étape 5 : Enregistrer le Bundle avec Capgo API »Enregistrer le bundle externe avec Capgo en utilisant des appels directs API :
async function registerWithCapgo(appId, version, bundleUrl, checksum, apiKey) { const fetch = require('node-fetch');
// Create bundle (version) const response = await fetch('https://api.capgo.app/bundle/', { method: 'POST', headers: { 'Content-Type': 'application/json', 'authorization': apiKey }, body: JSON.stringify({ app_id: appId, version: version, external_url: bundleUrl, checksum: checksum }) });
if (!response.ok) { throw new Error(`Failed to create bundle: ${response.statusText}`); }
const data = await response.json(); console.log('Bundle created:', data);
return data;}API Paramètres
Section intitulée « API Paramètres »| Paramètre | Description | Obligatoire |
|---|---|---|
app_id | Votre identifiant d'application | Oui |
version | Bundle (version) version semantique (par exemple, « 1.2.3 ») | Oui |
external_url | Accessible au public URL HTTPS où le bundle peut être téléchargé (pas d'authentification requise) | Oui |
checksum | Checksum SHA256 du fichier zip | Oui |
Exigences de structure du bundle
Section intitulée « Exigences de structure du bundle »Votre zip de bundle doit respecter ces exigences :
- Fichier d'index de niveau de racine: Doit avoir
index.htmlau niveau de racine - Capacitor Intégration: Doit appeler
notifyAppReady()In votre application code - Chemins d'asset: Utilisez des chemins relatifs pour tous les assets
Structure de paquet valide
Section intitulée “Structure de paquet valide”bundle.zip├── index.html├── assets/│ ├── app.js│ └── styles.css└── images/Exemple complet du flux de travail manuel
Section intitulée “Exemple complet du flux de travail manuel”Script Node.js simple pour zipper, calculer le checksum et envoyer à Capgo:
const fs = require('node:fs');const os = require('node:os');const AdmZip = require('adm-zip');const { checksum: getChecksum } = require('@tomasklaen/checksum');const fetch = require('node-fetch');
async function deployToCapgo() { const APP_ID = 'com.example.app'; const VERSION = '1.2.3'; const BUNDLE_URL = 'https://your-storage.com/bundles/app-1.2.3.zip'; const API_KEY = process.env.CAPGO_API_KEY;
// 1. Create zip (same as Capgo CLI) const zip = new AdmZip(); zip.addLocalFolder('./dist'); const zipped = zip.toBuffer();
// 2. Calculate checksum (same as Capgo CLI) const checksum = await getChecksum(zipped, 'sha256'); console.log('Checksum:', checksum);
// 3. Upload to your storage (replace with your upload logic) // fs.writeFileSync('./bundle.zip', zipped); // ... upload bundle.zip to your storage ...
// 4. Register with Capgo API const response = await fetch('https://api.capgo.app/bundle/', { method: 'POST', headers: { 'Content-Type': 'application/json', 'authorization': API_KEY }, body: JSON.stringify({ app_id: APP_ID, version: VERSION, external_url: BUNDLE_URL, checksum: checksum }) });
if (!response.ok) { throw new Error(`Failed: ${response.statusText}`); }
console.log('Bundle registered with Capgo!');}
deployToCapgo().catch(console.error);Installer les dépendances :
npm install adm-zip @tomasklaen/checksum node-fetchVérification du checksum
Section intitulée « Vérification du checksum »Calcul de checksum en JavaScript (Même que Capgo CLI)
Section intitulée « Calcul de checksum en JavaScript (Même que Capgo CLI) »Utilisez le même package et la même méthode que Capgo CLI utilise internement :
const fs = require('node:fs');const { checksum: getChecksum } = require('@tomasklaen/checksum');
async function calculateChecksum(filePath) { const fileBuffer = fs.readFileSync(filePath); // Use exact same package and method as Capgo CLI const checksum = await getChecksum(fileBuffer, 'sha256'); return checksum;}
// Verify checksum matchesasync function verifyChecksum(filePath, expectedChecksum) { const actualChecksum = await calculateChecksum(filePath); const isValid = actualChecksum === expectedChecksum;
console.log(`File: ${filePath}`); console.log(`Expected: ${expectedChecksum}`); console.log(`Actual: ${actualChecksum}`); console.log(`Valid: ${isValid}`);
return isValid;}
// Usageasync function main() { const bundleChecksum = await calculateChecksum('./my-app-1.2.3.zip'); console.log('SHA256 Checksum:', bundleChecksum);}
main();Importance du checksum
Section intitulée « Importance du checksum »- Intégrité du paquet : Assure que le paquet n'a pas été corrompu pendant le transfert
- API Vérification: Capgo vérifie les sommes de contrôle avant d'accepter les ensembles
- Vérification de Plugin: Le plugin mobile vérifie les sommes de contrôle avant d'appliquer les mises à jour
Meilleures Pratiques
Section intitulée “Meilleures Pratiques”- Gestion des Ensembles (version): Utilisez la versionnement semantique de manière cohérente Optimisation de Stockage
- : Supprimez périodiquement les ensembles non utilisésCompatibilité des Ensembles (version)
- Bundle (version) Management: Définissez les exigences de version native minimale appropriées
- Stratégie de sauvegarde: Gardez des sauvegardes des ensembles critiques (versions)
Points de terminaison
Section intitulée “Points de terminaison”https://api.capgo.app/bundle/
Récupérez les informations sur l'ensemble. Retourne 50 ensembles par page.
Paramètres de requête
Section intitulée “Paramètres de requête”app_id: Obligatoire. L'ID de votre applicationpage: Facultatif. Numéro de page pour la pagination
Type de réponse
Section intitulée “Type de réponse”interface Bundle { app_id: string bucket_id: string | null checksum: string | null created_at: string | null deleted: boolean external_url: string | null id: number minUpdateVersion: string | null name: string native_packages: Json[] | null owner_org: string r2_path: string | null session_key: string | null storage_provider: string updated_at: string | null user_id: string | null}Exemple de requête
Section intitulée “Exemple de requête”# Get all bundlescurl -H "authorization: your-api-key" \ "https://api.capgo.app/bundle/?app_id=app_123"
# Get next pagecurl -H "authorization: your-api-key" \ "https://api.capgo.app/bundle/?app_id=app_123&page=1"Exemple de réponse
Section intitulée “Exemple de réponse”{ "data": [ { "id": 1, "app_id": "app_123", "name": "1.0.0", "checksum": "abc123...", "minUpdateVersion": "1.0.0", "storage_provider": "r2", "created_at": "2024-01-01T00:00:00Z", "updated_at": "2024-01-01T00:00:00Z", "deleted": false, "owner_org": "org_123", "user_id": "user_123" } ]}SUPPRIMER
Section intitulée “SUPPRIMER”https://api.capgo.app/bundle/
Supprimer un ou plusieurs bundles pour une application. Utilisez avec prudence car cette action ne peut pas être annulée.
Paramètres de requête
Section intitulée “Paramètres de requête”Pour supprimer un bundle spécifique :
interface BundleDelete { app_id: string version: string}Pour supprimer tous les bundles :
interface BundleDeleteAll { app_id: string}Exemples de requêtes
Section intitulée “Exemples de requêtes”# Delete specific bundlecurl -X DELETE \ -H "authorization: your-api-key" \ -H "Content-Type: application/json" \ -d '{ "app_id": "app_123", "version": "1.0.0" }' \ https://api.capgo.app/bundle/
# Delete all bundlescurl -X DELETE \ -H "authorization: your-api-key" \ -H "Content-Type: application/json" \ -d '{ "app_id": "app_123" }' \ https://api.capgo.app/bundle/Réponse de succès
Section intitulée « Réponse de succès »{ "status": "ok"}https://api.capgo.app/bundle/
Créer un nouveau bundle avec une URL externe.
Corps de la demande
Section intitulée « Corps de la demande »interface CreateBundleBody { app_id: string version: string external_url: string // Must be publicly accessible HTTPS URL checksum: string}Exemple de demande
Section intitulée « Exemple de demande »curl -X POST \ -H "authorization: your-api-key" \ -H "Content-Type: application/json" \ -d '{ "app_id": "com.example.app", "version": "1.2.3", "external_url": "https://your-storage.com/bundles/app-1.2.3.zip", "checksum": "a1b2c3d4e5f6789abcdef123456789abcdef123456789abcdef123456789abcd" }' \ https://api.capgo.app/bundle/Réponse de Succès
Section intitulée « Réponse de Succès »{ "status": "ok"}POST (Métadonnées)
Section intitulée « POST (Métadonnées) »https://api.capgo.app/bundle/metadata
Mettre à jour les métadonnées du bundle, telles que les informations de lien et de commentaire.
Corps de la demande
Section intitulée « Corps de la demande »interface UpdateMetadataBody { app_id: string version_id: number // bundle (version) id link?: string comment?: string}Exemple de demande
Section intitulée « Exemple de demande »curl -X POST \ -H "authorization: your-api-key" \ -H "Content-Type: application/json" \ -d '{ "app_id": "app_123", "version_id": 456, "link": "https://github.com/myorg/myapp/releases/tag/v1.0.0", "comment": "Fixed critical bug in authentication" }' \ https://api.capgo.app/bundle/metadataRéponse de Succès
Section intitulée “Réponse de Succès”{ "status": "success"}https://api.capgo.app/bundle/
Associer un bundle à un canal spécifique. Cela relie un bundle (version) à un canal pour la distribution.
Corps de la demande
Section intitulée “Corps de la demande”interface SetChannelBody { app_id: string version_id: number // bundle (version) id channel_id: number}Exemple de demande
Section intitulée “Exemple de demande”curl -X PUT \ -H "authorization: your-api-key" \ -H "Content-Type: application/json" \ -d '{ "app_id": "app_123", "version_id": 456, "channel_id": 789 }' \ https://api.capgo.app/bundle/Réponse de succès
Section intitulée « Réponse de succès »{ "status": "success", "message": "Bundle 1.0.0 set to channel production"}Gestion des erreurs
Scénarios d'erreurs courants et leurs réponses :Copier dans le presse-papier
// Bundle not found{ "error": "Bundle not found", "status": "KO"}
// Invalid bundle (version) format{ "error": "Invalid version format", "status": "KO"}
// Storage error{ "error": "Failed to delete bundle from storage", "status": "KO"}
// Permission denied{ "error": "Insufficient permissions to manage bundles", "status": "KO"}Section intitulée « Utilisations courantes »
Nettoyage des anciens paquets (versions)- Copier dans le presse-papier
// Delete outdated beta bundles (versions){ "app_id": "app_123", "version": "1.0.0-beta.1"}- Réinitialiser l'application
// Remove all bundles to start fresh{ "app_id": "app_123"}Considérations de stockage
Section intitulée « Considérations de stockage »- Politique de conservation: Définir la durée de conservation des anciens ensembles
- Gestion de taille: Surveiller les tailles des ensembles et l'utilisation de stockage
- Stratégie de sauvegarde: Considérer la sauvegarde des ensembles critiques (versions)
- Optimisation des coûts: Supprimez les bundles inutiles pour optimiser les coûts de stockage
Continuez depuis Bundles
Section intitulée “Continuez depuis Bundles”Si vous utilisez Bundles pour planifier le stockage et la gestion des fichiers, connectez-le avec @capgo/capacitor-data-storage-sqlite pour les détails d'implémentation dans @capgo/capacitor-data-storage-sqlite, En utilisant @capgo/capacitor-data-storage-sqlite pour la capacité native dans En utilisant @capgo/capacitor-data-storage-sqlite, @capgo/capacitor-file pour les détails d'implémentation dans @capgo/capacitor-file, Utiliser @capgo/capacitor-fichier pour la capacité native dans Utiliser @capgo/capacitor-fichier, et @capgo/capacitor-téléchargeur pour le détail d'implémentation dans @capgo/capacitor-téléchargeur.