__CAPGO_KEEP_1__
이 플러그인의 설치 단계와 전체 마크다운 가이드를 포함한 설정 지시서를 복사하세요.
Capgo의 패키지 업데이트는 Bundles의 핵심입니다. 각 패키지는 웹 자산 (HTML, CSS, JS)으로 구성된 앱의 콘텐츠를 포함합니다. Bundles API은 이러한 업데이트 패키지를 관리하는 데 사용되며, 목록 및 삭제를 포함합니다.
Bundle 이해
“Bundle 이해”라는 제목의 섹션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 AppFirst, build your app’s web assets:
npm run build2단계: 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 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();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;}
// Usageasync 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 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"중요: __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.ziphttps://github.com/username/repo/releases/download/v1.2.3/bundle.ziphttps://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;}: API 매개변수
Section titled “API Parameters”| : 매개변수 | 설명 | 필수 |
|---|---|---|
app_id | 앱 식별자 | 예 |
version | 버nd (버전) Semantic 버전 (예를 들어, “1.2.3”) | 예 |
external_url | 공개적으로 접근 가능 HTTPS URL에서 버nd가 다운로드 될 수 있는 URL (인증이 필요하지 않음) | 예 |
checksum | zip 파일의 SHA256 체크섬 | Yes |
Bundle Structure Requirements
Bundle Structure Requirements__CAPGO_KEEP_0__을 따라야 하는 zip 파일 구조입니다:
- Root Index File: __CAPGO_KEEP_0__
index.html__CAPGO_KEEP_0__ - : CapacitorAsset Paths
notifyAppReady()in your app code - 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 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();체크섬의 중요성
__CAPGO_KEEP_0__ 체크섬의 중요성- 배달의 정확성: 배달 중에 손상되지 않은 것을 확인합니다.
- API 확인: Capgo 체크섬을 확인하기 전에 배달을 수락합니다.
- 플러그인 확인: 모바일 플러그인이 업데이트를 적용하기 전에 체크섬을 확인합니다.
Best Practices
Best Practices 섹션- Bundle (버전) 관리: 사용 일관된 semantic 버전을 사용하십시오 Storage Optimization
- : 사용하지 않는 Bundle를 정기적으로 제거하십시오Bundle (버전) 호환성
- : 적절한 최소 native 버전 요구 사항을 설정하십시오백업 전략
- : 중요한 Bundle (버전)의 백업을 유지하십시오__CAPGO_KEEP_0__
Endpoints
엔드포인트GET
GEThttps://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 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"예시 응답
예시 응답 섹션{ "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" } ]}DELETE
DELETE 섹션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 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/{ "status": "ok"}POST
POST 섹션 제목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
링크 및 댓글 정보와 같은 번들 메타데이터를 업데이트합니다.
Request Body
Request Body 섹션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__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"}일반 사용 사례
Section titled “일반 사용 사례”- 기존 버전의 패키지 정리
// Delete outdated beta bundles (versions){ "app_id": "app_123", "version": "1.0.0-beta.1"}- 앱 리셋
// Remove all bundles to start fresh{ "app_id": "app_123"}__CAPGO_KEEP_0__
__CAPGO_KEEP_1__- __CAPGO_KEEP_2____CAPGO_KEEP_3__
- __CAPGO_KEEP_4____CAPGO_KEEP_5__
- __CAPGO_KEEP_6____CAPGO_KEEP_7__
- __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-업로더 구현 세부 사항에 대해.