Channel API Endpoint
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Saluran adalah mekanisme inti untuk mengelola pembaruan aplikasi di Capgo. Di mode self-hosted, Anda perlu mengimplementasikan endpoint saluran untuk mengelola pengasasan perangkat, kueri saluran, dan operasi manajemen saluran.
Pengertian Saluran
Bab berjudul “Pengertian Saluran”Saluran memungkinkan Anda:
- Memantau distribusi pembaruan: Mengasignasikan versi aplikasi yang berbeda untuk kelompok pengguna yang berbeda
- Pengujian A/B: Menguji fitur baru dengan segment pengguna tertentu
- Rollout Terencana: Melindungi Risiko dengan Mengaktifkan Perbaruan secara Berangsur-angsur
- Pemisahan Lingkungan: Memisahkan Perbaruan Pengembangan, Pengujian, dan Produksi
Konfigurasi
Bagian KonfigurasiKonfigurasi URL Endpoint Saluran di capacitor.config.json:
{ "plugins": { "CapacitorUpdater": { "channelUrl": "https://myserver.com/api/channel_self" } }}Operasi Saluran
Bagian Operasi SaluranPlugin ini melakukan berbagai operasi saluran yang perlu dijalankan oleh endpoint Anda:
1. Daftar Saluran yang Kompatibel (Permintaan GET)
Bagian berjudul “1. Daftar Saluran yang Kompatibel (GET Request)”Saat plugin memanggil listChannels(), maka akan mengirimkan permintaan GET untuk mengambil semua saluran yang kompatibel dengan perangkat. Hal ini akan mengembalikan saluran yang sesuai dengan lingkungan perangkat (dev/prod, emulator/real device) dan memungkinkan akses publik atau pengasasan sendiri.
Format Permintaan
Bagian berjudul “Format Permintaan”// GET /api/channel_self// Headers:{ "Content-Type": "application/json"}
// Query parameters:interface ListChannelsRequest { app_id: string platform: "ios" | "android" | "electron" is_emulator: boolean is_prod: boolean key_id?: string}Format Respons
Bagian berjudul “Format Respons”[ { "id": 1, "name": "production", "public": true, "allow_self_set": false }, { "id": 2, "name": "beta", "public": false, "allow_self_set": true }]Mengerti Tipe Saluran
Bagian berjudul “Mengerti Tipe Saluran”Tanggapan termasuk dua flag penting untuk setiap saluran: __CAPGO_KEEP_0__
-
public: true: Ini adalah saluran default Saluran default. Perangkat tidak dapat menetapkan diri sendiri ke saluran ini menggunakansetChannel(). Sebaliknya, jika perangkat menghapus penugasan saluran (menggunakanunsetChannel()), maka perangkat akan secara otomatis menerima update dari saluran publik ini jika memenuhi syarat perangkat. -
allow_self_set: true: Ini adalah saluran yang dapat ditetapkan sendiri Saluran yang dapat ditetapkan sendiri. Perangkat dapat menetapkan diri sendiri ke saluran ini menggunakansetChannel(). Ini berguna untuk tes beta, tes A/B, atau memungkinkan pengguna untuk memilih masuk ke jalur update tertentu.
2. Dapatkan Saluran (Request PUT)
Judul bagian “2. Dapatkan Saluran (Request PUT)”Ketika plugin memanggil getChannel(), itu mengirimkan permintaan PUT untuk mengambil penugasan saluran perangkat saat ini.
Format Permintaan
Judul bagian “Format Permintaan”// PUT /api/channel_self// Headers:{ "Content-Type": "application/json"}
// Body:interface GetChannelRequest { device_id: string app_id: string platform: "ios" | "android" | "electron" plugin_version: string version_build: string version_code: string version_name: string is_emulator: boolean is_prod: boolean defaultChannel?: string channel?: string // For newer plugin versions, contains local channel override}Format Respon
Judul bagian “Format Respon”{ "status": "ok", "channel": "production", "allowSet": true, "message": "", "error": ""}3. Set Channel (POST Request)
Bagian berjudul “3. Set Channel (POST Request)”Ketika plugin memanggil setChannel(), maka mengirimkan permintaan POST untuk menetapkan perangkat ke saluran tertentu.
Format Permintaan
Bagian berjudul “Format Permintaan”// POST /api/channel_selfinterface SetChannelRequest { device_id: string app_id: string channel: string platform: "ios" | "android" | "electron" plugin_version: string version_build: string version_code: string version_name: string is_emulator: boolean is_prod: boolean}Format Respon
Bagian berjudul “Format Respon”{ "status": "ok", "message": "Device assigned to channel successfully", "error": ""}Kasus Kesalahan
Bagian berjudul “Kasus Kesalahan”Ketika perangkat mencoba untuk menetapkan dirinya ke sebuah saluran publik (saluran dengan public: true), endpoint Anda harus mengembalikan sebuah kesalahan:
{ "status": "error", "error": "public_channel_self_set_not_allowed", "message": "This channel is public and does not allow device self-assignment. Unset the channel and the device will automatically use the public channel."}Ketika perangkat mencoba untuk menetapkan dirinya ke sebuah saluran yang tidak memungkinkan penugasan diri sendiri:
{ "status": "error", "error": "channel_self_set_not_allowed", "message": "This channel does not allow devices to self associate"}4. Menghapus Saluran (DELETE Request)
Judul bagian “4. Menghapus Saluran (DELETE Request)”Ketika plugin memanggil unsetChannel(), itu mengirimkan sebuah permintaan DELETE untuk menghapus penugasan saluran perangkat.
Format Permintaan
Bagian berjudul “Format Permintaan”// DELETE /api/channel_selfinterface UnsetChannelRequest { device_id: string app_id: string platform: "ios" | "android" | "electron" plugin_version: string version_build: string version_code: string version_name: string}Contoh Implementasi
Bagian berjudul “Contoh Implementasi”Berikut adalah contoh JavaScript bagaimana cara mengimplementasikan endpoint channel:
interface ChannelRequest { device_id: string app_id: string channel?: string platform: "ios" | "android" | "electron" plugin_version: string version_build: string version_code: string version_name: string}
interface ChannelResponse { status: "ok" | "error" channel?: string allowSet?: boolean message?: string error?: string}
export const handler = async (event) => { const method = event.httpMethod || event.method const body = JSON.parse(event.body || '{}') as ChannelRequest
const { device_id, app_id, channel, platform } = body
try { switch (method) { case 'GET': return await getDeviceChannel(device_id, app_id)
case 'POST': return await setDeviceChannel(device_id, app_id, channel!, platform)
case 'DELETE': return await unsetDeviceChannel(device_id, app_id)
default: return { status: "error", error: "Method not allowed" } } } catch (error) { return { status: "error", error: error.message } }}
async function getDeviceChannel(deviceId: string, appId: string): Promise<ChannelResponse> { // Query your database for device channel assignment const assignment = await database.getDeviceChannel(deviceId, appId)
if (assignment) { return { status: "ok", channel: assignment.channel, allowSet: assignment.allowSelfAssign } }
// Return default channel if no assignment found return { status: "ok", channel: "production", // Your default channel allowSet: true }}
async function setDeviceChannel( deviceId: string, appId: string, channel: string, platform: string): Promise<ChannelResponse> { // Validate channel exists and allows self-assignment const channelConfig = await database.getChannelConfig(channel, appId)
if (!channelConfig) { return { status: "error", error: "Channel not found" } }
if (!channelConfig.allowDeviceSelfSet) { return { status: "error", error: "Channel does not allow self-assignment" } }
// Check platform restrictions if (platform === "ios" && !channelConfig.ios) { return { status: "error", error: "Channel not available for iOS" } }
if (platform === "android" && !channelConfig.android) { return { status: "error", error: "Channel not available for Android" } }
if (platform === "electron" && !channelConfig.electron) { return { status: "error", error: "Channel not available for Electron" } }
// Save the assignment await database.setDeviceChannel(deviceId, appId, channel)
return { status: "ok", message: "Device assigned to channel successfully" }}
async function unsetDeviceChannel(deviceId: string, appId: string): Promise<ChannelResponse> { // Remove device channel assignment await database.removeDeviceChannel(deviceId, appId)
return { status: "ok", message: "Device channel assignment removed" }}Konfigurasi Channel
Bagian berjudul “Konfigurasi Channel”Sistem channel Anda harus mendukung opsi konfigurasi ini:
interface ChannelConfig { name: string appId: string
// Platform targeting ios: boolean // Allow updates to iOS devices android: boolean // Allow updates to Android devices electron: boolean // Allow updates to Electron apps
// Device type restrictions allow_emulator: boolean // Allow updates on emulator/simulator devices allow_device: boolean // Allow updates on real/physical devices
// Build type restrictions allow_dev: boolean // Allow updates on development builds (is_prod=false) allow_prod: boolean // Allow updates on production builds (is_prod=true)
// Channel assignment public: boolean // Default channel - devices fall back to this when no override allowDeviceSelfSet: boolean // Allow devices to self-assign via setChannel()
// Update policies disableAutoUpdate: "major" | "minor" | "version_number" | "none" disableAutoUpdateUnderNative: boolean}Logika Pemfilteran Perangkat
Bagian berjudul “Logika Pemfilteran Perangkat”Ketika menampilkan saluran yang kompatibel (permintaan GET), Anda harus menyaring saluran berdasarkan kondisi-kondisi berikut:
- Pengecekan Platform : Saluran harus memungkinkan platform perangkat (
ios,android, atauelectron) - Pengecekan Tipe Perangkat:
- Jika
is_emulator=true: Saluran harus memilikiallow_emulator=true - Jika
is_emulator=false: Saluran harus memilikiallow_device=true
- Jika
- Pengecekan Tipe Pembangunan:
- Jika
is_prod=true: Saluran harus memilikiallow_prod=true - Jika
is_prod=falseChannel harus memilikiallow_dev=true
- Jika
- Pengecekan visibilitasChannel harus berupa
public=trueATAUallow_device_self_set=true
// Example filtering logicfunction getCompatibleChannels( platform: 'ios' | 'android' | 'electron', isEmulator: boolean, isProd: boolean, channels: ChannelConfig[]): ChannelConfig[] { return channels.filter(channel => { // Platform check if (!channel[platform]) return false
// Device type check if (isEmulator && !channel.allow_emulator) return false if (!isEmulator && !channel.allow_device) return false
// Build type check if (isProd && !channel.allow_prod) return false if (!isProd && !channel.allow_dev) return false
// Must be accessible (public or self-assignable) if (!channel.public && !channel.allowDeviceSelfSet) return false
return true })}Contoh Skema Basis Data
Judul bagian “Contoh Skema Basis Data”Anda perlu menyimpan konfigurasi channel dan penugasan perangkat:
-- Channels tableCREATE TABLE channels ( id SERIAL PRIMARY KEY, name VARCHAR(255) NOT NULL, app_id VARCHAR(255) NOT NULL,
-- Platform targeting ios BOOLEAN DEFAULT true, android BOOLEAN DEFAULT true, electron BOOLEAN DEFAULT true,
-- Device type restrictions allow_emulator BOOLEAN DEFAULT true, -- Allow emulator/simulator devices allow_device BOOLEAN DEFAULT true, -- Allow real/physical devices
-- Build type restrictions allow_dev BOOLEAN DEFAULT true, -- Allow development builds allow_prod BOOLEAN DEFAULT true, -- Allow production builds
-- Channel assignment public BOOLEAN DEFAULT false, -- Default channel (fallback) allow_device_self_set BOOLEAN DEFAULT false, -- Allow self-assignment
-- Update policies disable_auto_update VARCHAR(50) DEFAULT 'none', disable_auto_update_under_native BOOLEAN DEFAULT false,
created_at TIMESTAMP DEFAULT NOW(), UNIQUE(name, app_id));
-- Device channel assignments tableCREATE TABLE device_channels ( id SERIAL PRIMARY KEY, device_id VARCHAR(255) NOT NULL, app_id VARCHAR(255) NOT NULL, channel_name VARCHAR(255) NOT NULL, assigned_at TIMESTAMP DEFAULT NOW(), UNIQUE(device_id, app_id));Pengelolaan Kesalahan
Judul bagian “Pengelolaan Kesalahan”Mengatasi skenario kesalahan umum:
// Channel not found{ "status": "error", "error": "Channel 'beta' not found"}
// Self-assignment not allowed{ "status": "error", "error": "Channel does not allow device self-assignment"}
// Platform not supported{ "status": "error", "error": "Channel not available for this platform"}
// Invalid request{ "status": "error", "error": "Missing required field: device_id"}Praktik Terbaik
Bab berjudul “Praktik Terbaik”- Keamanan: Validasi semua pengaturan saluran terhadap aturan bisnis Anda
- Pengelolaan Log: Log semua operasi saluran untuk auditing dan debugging
- Kinerja: Cache pengaturan saluran untuk mengurangi kueri database
- Validasi: Verifikasi keaslian device_id dan app_id
- Pengaturan Batasan: Implementasikan batasan rate untuk mencegah penyalahgunaan
Integrasi dengan Perbarui
Bagian berjudul “Integrasi dengan Perbarui”Penugasan saluran bekerja sama dengan Perbarui API Endpoint. Ketika perangkat meminta perbarui, periksa penugasan saluran untuk menentukan versi mana yang harus disajikan:
async function getUpdateForDevice(deviceId: string, appId: string) { // Get device's channel assignment const channelAssignment = await getDeviceChannel(deviceId, appId) const channel = channelAssignment.channel || 'production'
// Get the version assigned to this channel const channelVersion = await getChannelVersion(channel, appId)
return { version: channelVersion.version, url: channelVersion.url, checksum: channelVersion.checksum }}Hal ini menciptakan sistem manajemen saluran mandiri yang lengkap sehingga memberikan Anda kendali penuh atas bagaimana perbarui disebarkan kepada pengguna Anda.
Lanjutkan dari Saluran API Endpoint
Bagian berjudul “Lanjutkan dari Saluran API Endpoint”Jika Anda menggunakan Saluran API Endpoint untuk merencanakan routing saluran dan peluncuran tahap demi tahap, hubungkannya dengan Menggunakan @capgo/capacitor-updater untuk kemampuan asli dalam Menggunakan @capgo/capacitor-updater, Saluran-Saluran untuk detail implementasi dalam Saluran-Saluran, Saluran-Saluran untuk detail implementasi dalam Saluran-Saluran, Saluran-Saluran untuk detail implementasi dalam Saluran-Saluran, dan Solusi Uji Beta untuk alur kerja produk dalam Solusi Uji Beta.