Aller directement au contenu

Bundles

Bundles are the core update packages in Capgo. Each bundle contains the web assets (HTML, CSS, JS) that make up your app’s content. The Bundles API allows you to manage these update packages, including listing and deleting them.

Un bundle représente une version spécifique du contenu web de votre application et comprend :

  • Bundle (version): Numéro de version semantique du bundle
  • Checksum: Hash unique pour vérifier l'intégrité du bundle
  • Informations de stockage: Détails sur la façon et le lieu où 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

Voici comment créer et télécharger des bundles manuellement sans utiliser le Capgo CLI:

Tout d’abord, construisez les actifs web de votre application :

Fenêtre de terminal
npm run build

Étape 2 : Créer un Zip de Bundle en Utilisant les Mêmes Packages que Capgo CLI

Section intitulée “Étape 2 : Créer un 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é.

Fenêtre de terminal
npm install adm-zip @tomasklaen/checksum

Créer un fichier ZIP avec JavaScript (Même chose que Capgo CLI)

Section intitulée « Créer un fichier ZIP avec JavaScript (Même chose que Capgo CLI) »

Remarque : Dans les exemples ci-dessous, version fait référence au nom du fichier ZIP (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 CLI
function 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
};
}
// Usage
async 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;
}
// Usage
async function main() {
const checksum = await calculateChecksum('./my-app-1.2.3.zip');
console.log('Checksum:', checksum);
}
main();

Étape 4 : Télécharger le Bundle dans votre Stockage

Section intitulée « Étape 4 : Télécharger le Bundle dans votre Stockage »

Téléchargez votre fichier zip dans n'importe quel stockage accessible en ligne :

Fenêtre de terminal
# Example: Upload to your server via scp
scp my-app-1.2.3.zip user@your-server.com:/var/www/bundles/
# Example: Upload to S3 using AWS CLI
aws s3 cp my-app-1.2.3.zip s3://your-bucket/bundles/
# Example: Upload via curl to a custom endpoint
curl -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 authentification requise). Les serveurs de Capgo doivent télécharger le bundle à partir de cette URL.

Exemples de URL publiques valides :

  • https://your-storage.com/bundles/my-app-1.2.3.zip
  • https://github.com/username/repo/releases/download/v1.2.3/bundle.zip
  • https://cdn.jsdelivr.net/gh/username/repo@v1.2.3/dist.zip

Inscrivez le bundle externe avec Capgo à l'aide d'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;
}
ParamètreDescriptionObligatoire
app_idVotre identifiant d'applicationOui
versionBundle (version) version semantique (par exemple, « 1.2.3 »)Oui
external_urlAccessible au public URL HTTPS où le bundle peut être téléchargé (pas d'authentification requise)Oui
checksumChecksum SHA256 du fichier zipOui

Votre zip de bundle doit respecter ces exigences :

  1. Fichier d'index de niveau de racine: Doit avoir index.html au niveau de racine
  2. Capacitor Intégration: Doit appeler notifyAppReady() dans votre application code
  3. Chemins d'assets: Utilisez des chemins relatifs pour tous les assets
bundle.zip
├── index.html
├── assets/
│ ├── app.js
│ └── styles.css
└── images/

Script Node.js simple pour zipper, calculer la checksum et télécharger sur 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);

Installez les dépendances :

Fenêtre de terminal
npm install adm-zip @tomasklaen/checksum node-fetch

Calcul de l'intégrité JavaScript (Même que Capgo CLI)

Section intitulée « Calcul de l'intégrité 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 matches
async 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;
}
// Usage
async function main() {
const bundleChecksum = await calculateChecksum('./my-app-1.2.3.zip');
console.log('SHA256 Checksum:', bundleChecksum);
}
main();
  • Intégrité du paquetAssure 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 des plugins: Le plugin mobile vérifie les sommes de contrôle avant d'appliquer les mises à jour
  1. Gestion des Ensembles (version): Utilisez la versionnement semantique de manière cohérente
  2. Optimisation de Stockage: Supprimez périodiquement les ensembles non utilisés
  3. Compatibilité des Ensembles (version): Définissez les exigences de version native minimale appropriées
  4. Stratégie de Sauvegarde: Maintenez des sauvegardes des bundles critiques (versions)

https://api.capgo.app/bundle/

Récupérez les informations sur le bundle. Retourne 50 bundles par page.

  • app_id: Obligatoire. L'ID de votre application
  • page: Facultatif. Numéro de page pour la pagination
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
}
Fenêtre de terminal
# Get all bundles
curl -H "authorization: your-api-key" \
"https://api.capgo.app/bundle/?app_id=app_123"
# Get next page
curl -H "authorization: your-api-key" \
"https://api.capgo.app/bundle/?app_id=app_123&page=1"
{
"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"
}
]
}

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.

Pour supprimer un bundle spécifique :

interface BundleDelete {
app_id: string
version: string
}

Pour supprimer tous les bundles :

interface BundleDeleteAll {
app_id: string
}
Fenêtre de terminal
# Delete specific bundle
curl -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 bundles
curl -X DELETE \
-H "authorization: your-api-key" \
-H "Content-Type: application/json" \
-d '{
"app_id": "app_123"
}' \
https://api.capgo.app/bundle/
{
"status": "ok"
}

https://api.capgo.app/bundle/

Créez un nouveau bundle avec une URL externe.

interface CreateBundleBody {
app_id: string
version: string
external_url: string // Must be publicly accessible HTTPS URL
checksum: string
}
Fenêtre de terminal
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/
{
"status": "ok"
}

https://api.capgo.app/bundle/metadata

Mettre à jour les métadonnées du bundle, telles que les informations de lien et de commentaire.

interface UpdateMetadataBody {
app_id: string
version_id: number // bundle (version) id
link?: string
comment?: string
}
Fenêtre de terminal
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/metadata
{
"status": "success"
}

https://api.capgo.app/bundle/

Définir un ensemble de fichiers pour un canal spécifique. Cela relie un ensemble de fichiers (version) à un canal pour la distribution.

interface SetChannelBody {
app_id: string
version_id: number // bundle (version) id
channel_id: number
}
Fenêtre de terminal
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/
{
"status": "success",
"message": "Bundle 1.0.0 set to channel production"
}

Scénarios d'erreurs courants et leurs réponses :

// 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"
}
  1. Nettoyage des anciens Bundles (Versions)
// Delete outdated beta bundles (versions)
{
"app_id": "app_123",
"version": "1.0.0-beta.1"
}
  1. Réinitialisation de l'Application
// Remove all bundles to start fresh
{
"app_id": "app_123"
}
  1. Politique de conservation: Définir combien de temps conserver les anciens ensembles
  2. Gestion de taille: Surveiller les tailles des ensembles et l'utilisation de stockage
  3. Stratégie de sauvegarde: Considérer la sauvegarde des ensembles critiques (versions)
  4. Optimisation des coûts: Supprimer les ensembles inutiles pour optimiser les coûts de stockage