채널 API 엔드포인트
이 플러그인의 설치 단계와 전체 마크다운 가이드를 포함한 설정 프롬프트를 복사하세요.
Capgo에서 앱 업데이트를 관리하는 핵심 메커니즘인 채널입니다. 자체 호스팅 모드에서, 디바이스 할당, 채널 쿼리 및 채널 관리 작업을 처리하기 위해 채널 엔드포인트를 implement해야합니다.
채널 이해
채널 이해채널을 사용하면:
- 업데이트 배포를 제어할 수 있습니다.다양한 사용자 그룹에 다른 앱 버전을 assign할 수 있습니다.
- A/B 테스트새로운 기능을 특정 사용자 세그먼트와 함께 테스트할 수 있습니다.
- 스테이지드 롤아웃: __CAPGO_KEEP_0__
- 환경 분리: 개발, 스테이징 및 프로덕션 업데이트를 분리하세요
설정
설정__CAPGO_KEEP_0__에서 채널 엔드포인트 URL을 구성하세요 capacitor.config.json:
{ "plugins": { "CapacitorUpdater": { "channelUrl": "https://myserver.com/api/channel_self" } }}1. 호환 가능한 채널 목록 조회 (GET 요청)
1. 호환 가능한 채널 목록 조회 (GET 요청)
채널 연산을 수행하는 플러그인이 __CAPGO_KEEP_0__에서 처리해야 하는 다양한 연산입니다:When the plugin calls __CAPGO_KEEP_0__ , it sends a GET request to retrieve all channels that are compatible with the device. This returns channels that match the device’s environment (dev/prod, emulator/real device) and allow either public access or self-assignment. listChannels()요청 형식
__CAPGO_KEEP_0__
복사// 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}__CAPGO_KEEP_0__
복사[ { "id": 1, "name": "production", "public": true, "allow_self_set": false }, { "id": 2, "name": "beta", "public": false, "allow_self_set": true }]__CAPGO_KEEP_0__
응답에는 각 채널에 대한 두 가지 중요한 플래그가 포함됩니다.: 이 플래그는
-
public: true: 이 플래그는 기본 채널. 장치가 자동으로 할당되지 못합니다.setChannel(). 장치가 채널 할당을 취소하면 (unsetChannel()), 이 공용 채널의 업데이트를 자동으로 받게 됩니다. 장치의 조건과 일치할 경우. -
allow_self_set: true: 이 채널은 자신이 할당할 수 있는 채널입니다.. 장치가 직접 이 채널에 할당할 수 있습니다.setChannel(). 베타 테스트, A/B 테스트, 또는 사용자가 특정 업데이트 트랙에 가입할 수 있도록 허용하는 데 유용합니다.
2. 채널 가져오기 (PUT 요청)
제목 '2. 채널 가져오기 (PUT 요청)'플러그인이 호출하면 getChannel()이것은 기기의 현재 채널 assignement을 가져오기 위해 PUT 요청을 보낸다.
요청 형식
제목 '요청 형식'// 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}응답 형식
제목 '응답 형식'{ "status": "ok", "channel": "production", "allowSet": true, "message": "", "error": ""}3. 채널 설정 (POST 요청)
Section titled “3. 채널 설정 (POST 요청)”플러그인이 호출할 때 setChannel(), 이 요청은 특정 채널에 장치를 할당하기 위해 POST 요청을 보냅니다.
// 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}{ "status": "ok", "message": "Device assigned to channel successfully", "error": ""}장치가 자신을 할당하려고 할 때 공개 채널 (one with public: true), endpoint에서 오류를 반환해야 합니다:
{ "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."}장치가 자체 할당을 허용하지 않는 채널에 할당하려 할 때 장치가 시도하는 경우:
{ "status": "error", "error": "channel_self_set_not_allowed", "message": "This channel does not allow devices to self associate"}4. 채널 해제 (DELETE Request)
제목: 4. 채널 해제 (DELETE Request)플러그인이 호출할 때, unsetChannel()장치의 채널 할당을 삭제하기 위해 DELETE 요청을 보냅니다.
요청 형식
제목: 요청 형식// 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}Implementation Example
Implementation Example 구간JavaScript를 사용하여 채널 엔드포인트를 구현하는 예제입니다.
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" }}채널 구성
채널 구성 구간채널 시스템은 다음 구성 옵션을 지원해야 합니다.
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}장치 필터링 논리
장치 필터링 논리 구간호환 가능한 채널 목록을 가져올 때 (GET 요청), 다음 조건에 따라 채널을 필터링해야 합니다.
- 플랫폼 확인: 채널은 기기의 플랫폼을 허용해야 합니다 (
ios,android, 또는electron) - 기기 종류 확인:
- 만약
is_emulator=true: 채널은 기기의 플랫폼을 허용해야 합니다allow_emulator=true - 만약
is_emulator=false: 채널은 기기의 플랫폼을 허용해야 합니다allow_device=true
- 만약
- 빌드 타입 확인:
- 만약
is_prod=true: 채널은 기기의 플랫폼을 허용해야 합니다allow_prod=true - 만약
is_prod=false__CAPGO_KEEP_0__ 채널이 있어야 합니다.allow_dev=true
- 만약
- __CAPGO_KEEP_0__ 채널의 가시성 확인__CAPGO_KEEP_0__ 채널이거나
public=true또는allow_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 })}__CAPGO_KEEP_1__ 데이터베이스 스키마 예시
__CAPGO_KEEP_1__ 데이터베이스 스키마 예시__CAPGO_KEEP_2__ 채널 설정 및 장치 할당을 저장해야 합니다.
-- 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));__CAPGO_KEEP_3__ 오류 처리
__CAPGO_KEEP_3__ 오류 처리 시나리오를 처리해야 합니다.__CAPGO_KEEP_0__
// 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"}Best Practices
'Best Practices' 제목의 섹션- 보안: 사업 규칙에 따라 모든 채널 assignments를 검증하세요
- 로그: 감사 및 디버깅을 위해 모든 채널 연산을 로깅하세요
- 성능: 데이터베이스 쿼리 수를 줄이기 위해 채널 구성 캐시하세요
- 검증: device_id 및 app_id의 진위성을 확인하세요
- 속도 제한: __CAPGO_KEEP_0__ 방지하기 위해 오버루프를 구현하세요.
업데이트 통합
업데이트 통합 섹션채널 assignments는 사용자에게 업데이트를 어떻게 배포할지에 대한 완전한 제어를 제공하는 완전한 자체 호스팅 채널 관리 시스템을 만듭니다. API 업데이트 엔드포인트장치가 업데이트를 요청할 때, 채널 assignments를 확인하여 어떤 버전을 제공할지 결정하세요.
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 }}채널 assignments는 사용자에게 업데이트를 어떻게 배포할지에 대한 완전한 제어를 제공하는 완전한 자체 호스팅 채널 관리 시스템을 만듭니다.
채널 __CAPGO_KEEP_0__ 엔드포인트 섹션 API를 사용하는 경우 채널 라우팅과 스테이지 롤아웃을 계획하고 연결하세요. Using @capgo/capacitor-updater Using @capgo/capacitor-updater 채널 채널 채널 채널 Beta 테스트 솔루션 Beta 테스트 솔루션 Beta 테스트 솔루션 Beta 테스트 솔루션