Skip to content

__CAPGO_KEEP_1__

Capgo의 패키지 업데이트는 Bundles의 핵심입니다. 각 패키지는 웹 자산 (HTML, CSS, JS)으로 구성된 앱의 콘텐츠를 포함합니다. Bundles API은 이러한 업데이트 패키지를 관리하는 데 사용되며, 목록 및 삭제를 포함합니다.

Bundle은 특정 버전의 앱의 웹 콘텐츠를 나타내며 다음을 포함합니다:

  • Bundle (버전): Semantic 버전 번호 Bundle의 버전
  • Checksum: __CAPGO_KEEP_0__을 확인하여 번들 무결성을 검증하는 고유 해시
  • Storage Info: 번들이 저장되는 위치와 방법에 대한 세부 정보
  • Native Requirements: 최소 네이티브 앱 버전 요구 사항
  • Metadata: 생성 시간, 소유권 및 기타 추적 정보

Manual Bundle Creation (Without CLI)

Manual Bundle Creation (Without CLI)

Here’s how to create and upload bundles manually without using the Capgo CLI:

Step 1: Build Your App

Step 1: Build Your App

First, build your app’s web assets:

터미널 창
npm run build

2단계: Capgo CLI과 동일한 패키지를 사용하여 Bundle Zip을 생성합니다.

2단계: Capgo CLI과 동일한 패키지를 사용하여 Bundle Zip을 생성합니다. (섹션 제목)

중요: Capgo CLI 내부에서 사용하는 정확한 자바스크립트 패키지를 사용하여 호환성을 보장합니다.

터미널 창
npm install adm-zip @tomasklaen/checksum

자바스크립트와 동일한 패키지를 사용하여 Zip Bundle을 생성합니다 (Capgo CLI과 동일한 패키지)

자바스크립트와 함께 ZIP 보관함 만들기 (Capgo CLI와 동일)

주의: 아래 예시에서 version 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();

3단계: CLI과 동일한 패키지를 사용하여 SHA256 체크섬 계산

3단계: CLI과 동일한 패키지를 사용하여 SHA256 체크섬 계산
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();

4단계: 저장소에 업로드

4단계: 저장소에 업로드

ZIP 파일을 웹에 접근 가능한 저장소에 업로드하세요:

터미널 창
# 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"

중요: __CAPGO_KEEP_0__의 번들은 : HTTPS URL을 통해 공개적으로 접근할 수 있어야 합니다 (인증이 필요하지 않습니다). __CAPGO_KEEP_0__의 서버는 이 URL에서 번들을 다운로드해야 합니다. via HTTPS URL (no authentication required). Capgo’s servers need to download the bundle from this URL.

: 5단계: __CAPGO_KEEP_0__ __CAPGO_KEEP_1__에 번들을 등록하세요

  • 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

: 5단계: Capgo API에 번들을 등록하세요

: Capgo의 외부 번들을 API을 직접 호출하여 등록하세요:

Register the external bundle with Capgo using direct API calls:

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;
}
: 매개변수설명필수
app_id앱 식별자
version버nd (버전) Semantic 버전 (예를 들어, “1.2.3”)
external_url공개적으로 접근 가능 HTTPS URL에서 버nd가 다운로드 될 수 있는 URL (인증이 필요하지 않음)
checksumzip 파일의 SHA256 체크섬Yes

Bundle Structure Requirements

Bundle Structure Requirements

__CAPGO_KEEP_0__을 따라야 하는 zip 파일 구조입니다:

  1. Root Index File: __CAPGO_KEEP_0__ index.html __CAPGO_KEEP_0__
  2. : CapacitorAsset Paths notifyAppReady() in your app code
  3. Must have __CAPGO_KEEP_0__ at the root levelMust call __CAPGO_KEEP_0__ in your app

정상적인 번들 구조

정상적인 번들 구조 섹션
bundle.zip
├── index.html
├── assets/
│ ├── app.js
│ └── styles.css
└── images/

완전한 수동 워크플로 예제

완전한 수동 워크플로 예제 섹션

Capgo으로 압축, 체크섬, 업로드하는 간단한 Node.js 스크립트

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);

의존성 설치:

터미널 창
npm install adm-zip @tomasklaen/checksum node-fetch

체크섬 검증

체크섬 검증 섹션

자바스크립트 체크섬 계산 (Capgo CLI과 동일)

Capgo CLI과 동일한 자바스크립트 체크섬 계산

Capgo 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;
}
// 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();
  • 배달의 정확성: 배달 중에 손상되지 않은 것을 확인합니다.
  • API 확인: Capgo 체크섬을 확인하기 전에 배달을 수락합니다.
  • 플러그인 확인: 모바일 플러그인이 업데이트를 적용하기 전에 체크섬을 확인합니다.

Best Practices

Best Practices 섹션
  1. Bundle (버전) 관리: 사용 일관된 semantic 버전을 사용하십시오 Storage Optimization
  2. : 사용하지 않는 Bundle를 정기적으로 제거하십시오Bundle (버전) 호환성
  3. : 적절한 최소 native 버전 요구 사항을 설정하십시오백업 전략
  4. : 중요한 Bundle (버전)의 백업을 유지하십시오__CAPGO_KEEP_0__

GET

GET

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

배포 정보를 가져옵니다. 50개씩 페이지당 배포 정보를 반환합니다.

Query Parameters

엔드포인트
  • app_id: 앱 ID입니다. 필수입니다.
  • page: 페이지 번호입니다. (페이지네이션을 위해)

Response Type

응답 형식
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
}
터미널 창
# 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/

앱의 모든 패키지를 삭제하거나 하나의 패키지를 삭제합니다. 이 작업은 되돌릴 수 없으므로 주의가 필요합니다.

쿼리 매개변수

쿼리 매개변수 섹션

__CAPGO_KEEP_0__ 삭제를 위해 특정 번들:

interface BundleDelete {
app_id: string
version: string
}

__CAPGO_KEEP_0__ 삭제를 위해 모든 번들을 삭제:

interface BundleDeleteAll {
app_id: string
}
터미널 창
# 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/

새로운 외부 URL을 가진 번들 만들기.

interface CreateBundleBody {
app_id: string
version: string
external_url: string // Must be publicly accessible HTTPS URL
checksum: string
}
터미널 창
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"
}

POST (Metadata)

POST (Metadata) 섹션

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

링크 및 댓글 정보와 같은 번들 메타데이터를 업데이트합니다.

interface UpdateMetadataBody {
app_id: string
version_id: number // bundle (version) id
link?: string
comment?: string
}
터미널 창
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"
}

__CAPGO_KEEP_1__

__CAPGO_KEEP_2__

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

__CAPGO_KEEP_3__

__CAPGO_KEEP_4__

__CAPGO_KEEP_5__
interface SetChannelBody {
app_id: string
version_id: number // bundle (version) id
channel_id: number
}

__CAPGO_KEEP_7__

__CAPGO_KEEP_8__
__CAPGO_KEEP_9__
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/

__CAPGO_KEEP_11__

성공 응답
{
"status": "success",
"message": "Bundle 1.0.0 set to channel production"
}

일반 오류 상황 및 응답:

// 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. 기존 버전의 패키지 정리
// Delete outdated beta bundles (versions)
{
"app_id": "app_123",
"version": "1.0.0-beta.1"
}
  1. 앱 리셋
// Remove all bundles to start fresh
{
"app_id": "app_123"
}

__CAPGO_KEEP_0__

__CAPGO_KEEP_1__
  1. __CAPGO_KEEP_2____CAPGO_KEEP_3__
  2. __CAPGO_KEEP_4____CAPGO_KEEP_5__
  3. __CAPGO_KEEP_6____CAPGO_KEEP_7__
  4. __CAPGO_KEEP_8____CAPGO_KEEP_9__

__CAPGO_KEEP_10__

__CAPGO_KEEP_11__

만약에 번들 파일 처리와 저장을 계획하고 싶다면 @capgo/capacitor-data-storage-sqlite @capgo/capacitor-data-storage-sqlite의 구현 세부 사항을 참조하십시오. @capgo/capacitor-data-storage-sqlite @capgo/capacitor-data-storage-sqlite을 사용하여 @capgo/capacitor-data-storage-sqlite @capgo/capacitor-data-storage-sqlite을 사용하여 @capgo/capacitor-file @capgo/capacitor-file의 구현 세부 사항을 참조하십시오. @capgo/capacitor-file을 사용하여 @capgo/capacitor-업로더 구현 세부 사항에 대해.