Almacenamiento personalizado
Copiar un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
Capgo admite soluciones de almacenamiento personalizadas para los paquetes de su aplicación, lo que le permite alojar sus actualizaciones en su propia infraestructura o servicios de almacenamiento de terceros. Esto es particularmente útil para organizaciones con requisitos de seguridad específicos, necesidades de cumplimiento o infraestructura de almacenamiento existente.
Resumen
Sección titulada “Resumen”El almacenamiento personalizado en Capgo funciona subiendo su paquete a una ubicación externa y proporcionando a Capgo la URL para acceder a él. El Capgo SDK descargará actualizaciones directamente desde su ubicación de almacenamiento personalizado en lugar de la almacenamiento en la nube predeterminado de Capgo.
Subir URL externa
Sección titulada “Subir URL externa”La forma más sencilla de usar almacenamiento personalizado es subiendo tu paquete a cualquier URL accesible públicamente y proporcionando esa URL a Capgo.
Subir URL externa básica
Sección titulada “Subir URL externa básica”npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zipEste comando le dice a Capgo que refiera el paquete en la URL especificada en lugar de subirlo a la almacenamiento en la nube de Capgo’s.
Con cifrado
Sección titulada “Con cifrado”Para almacenamiento externo seguro, puedes cifrar tu paquete y proporcionar las claves de descifrado:
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip --iv-session-key YOUR_IV_SESSION_KEYIntegración de S3
Sección titulada “Integración de S3”Capgo ofrece soporte integrado para Amazon S3 y servicios de almacenamiento S3 compatibles. El CLI puede subir automáticamente su paquete a S3 y configurar Capgo para utilizar la URL de S3.
Opciones de carga de S3
Sección titulada “Opciones de carga de S3”npx @capgo/cli@latest bundle upload \ --s3-region us-east-1 \ --s3-apikey YOUR_ACCESS_KEY \ --s3-apisecret YOUR_SECRET_KEY \ --s3-bucket-name your-bucket-nameConfiguración de S3 completa
Sección titulada “Configuración de S3 completa”Para servicios compatibles con S3 o puntos finales personalizados:
npx @capgo/cli@latest bundle upload \ --s3-region us-east-1 \ --s3-apikey YOUR_ACCESS_KEY \ --s3-apisecret YOUR_SECRET_KEY \ --s3-endpoint https://s3.your-provider.com \ --s3-bucket-name your-bucket-name \ --s3-port 443 \ --no-s3-ssl # Only if your endpoint doesn't support SSLParámetros de configuración de S3
Sección titulada “Parámetros de configuración de S3”| Parámetro | Descripción | Requerido |
|---|---|---|
--s3-region | Región de AWS para tu contenedor S3 | Sí |
--s3-apikey | ID de clave de acceso de S3 | Sí |
--s3-apisecret | Clave secreta de acceso de S3 | Sí |
--s3-bucket-name | Nombre de tu recipiente S3 | Sí |
--s3-endpoint | URL personalizada del extremo de S3 | No |
--s3-port | Puerto para el extremo de S3 | No |
--no-s3-ssl | Deshabilitar SSL para la carga de S3 | No |
Preparación y cifrado del paquete
Sección titulada “Preparación y cifrado del paquete”Al utilizar almacenamiento personalizado, especialmente con cifrado, debes preparar tus paquetes correctamente. Esto implica crear un archivo zip y cifrarlo opcionalmente.
Paso 1: Crear un paquete Zip
Sección titulada “Paso 1: Crear un archivo Zip”Primero, crea un archivo zip de tu archivo de paquete:
npx @capgo/cli@latest bundle zip com.example.app --path ./distEl comando zip devolverá el checksum del archivo zip. Puedes utilizar este checksum para cifrar el archivo zip si es necesario. Utiliza el --json opción para obtener un resultado estructurado que incluya el checksum.
Opciones del comando Zip
Sección titulada “Opciones del comando Zip”npx @capgo/cli@latest bundle zip [appId] \ --path ./dist \ --bundle 1.2.3 \ --name myapp-v1.2.3 \ --json \ --no-code-check \ --key-v2 \ --package-json ../../package.json,./package.json| Opción | Descripción |
|---|---|
--path | Ruta al folder para comprimir (por defecto webDir de capacitor.config) |
--bundle | Versión del paquete para nombrar el archivo zip |
--name | Nombre personalizado para el archivo zip |
--json | Resultados de salida en formato JSON (incluye checksum) |
--no-code-check | Saltarse la comprobación de la llamada a notifyAppReady() y el archivo de índice |
--key-v2 | Usar cifrado v2 |
--package-json | Rutas a archivos package.json para repositorios monorepo (separados por comas) |
Paso 2: Cifrar el Bundle (Opcional)
Sección titulada “Paso 2: Cifrar el Bundle (Opcional)”Para una mayor seguridad, cifre su archivo zip antes de subirlo:
# Using default local keynpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM
# Using custom key filenpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key ./path/to/.capgo_key_v2
# Using key data directlynpx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key-data "PRIVATE_KEY_CONTENT"The parameter is required and should be the checksum of your zip file. You can get the checksum from the zip command output (use the CHECKSUM option for structured output). --json Por defecto, el comando de cifrado utilizará tu clave privada de firma local. Puedes especificar una clave personalizada utilizando el
o --key opciones. --key-data El comando de cifrado devolverá el
necesario para la subida o la desifrado. ivSessionKey Opciones del comando de cifrado
Sección titulada “Opciones del comando de cifrado”
Opción| Descripción | Option __CAPGO_KEEP_0__ is required and should be the checksum of your zip file. You can get the checksum from the zip command output (use the __CAPGO_KEEP_1__ option for structured output). |
|---|---|
zipPath | Ruta al archivo zip para cifrar (obligatorio) |
checksum | Checksum del archivo zip (obligatorio) - obténlo con el comando zip |
--key | Ruta personalizada para la clave de firma privada (opcional, utiliza la clave local por defecto) |
--key-data | Datos de la clave de firma privada directamente (opcional) |
--json | Los resultados se muestran en formato JSON |
Ejemplos de flujo de trabajo completo
Sección titulada “Ejemplos de flujo de trabajo completo”Ejemplo 1: URL externa con cifrado
Sección titulada “Ejemplo 1: URL externa con cifrado”-
Construye tu aplicación:
Ventana de terminal npm run build -
Crear un archivo zip:
Ventana de terminal npx @capgo/cli@latest bundle zip com.example.app --path ./dist --bundle 1.2.3Nota el checksum devuelto por este comando.
-
Cifra el archivo zip:
Ventana de terminal npx @capgo/cli@latest bundle encrypt ./com.example.app-1.2.3.zip CHECKSUM_FROM_STEP_2Nota el
ivSessionKeydesde la salida. -
Subir a tu almacenamiento: Subir el archivo zip cifrado a tu servicio de alojamiento.
-
Registra con Capgo:
Ventana de terminal npx @capgo/cli@latest bundle upload \--external https://your-cdn.com/bundles/com.example.app-1.2.3.zip \--iv-session-key IV_SESSION_KEY_FROM_STEP_3
Ejemplo 2: Carga directa a S3
Sección titulada “Ejemplo 2: Carga directa a S3”-
Construye tu aplicación:
Ventana de terminal npm run build -
Subir directamente a S3:
Ventana de terminal npx @capgo/cli@latest bundle upload \--s3-region us-west-2 \--s3-apikey YOUR_ACCESS_KEY \--s3-apisecret YOUR_SECRET_KEY \--s3-bucket-name your-app-bundles \--channel Production
Ejemplo 3: S3 con cifrado
Título de la sección “Ejemplo 3: S3 con cifrado”-
Compilar y comprimir:
Ventana de terminal npm run buildnpx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2 -
Cifrar el paquete:
Ventana de terminal npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM -
Subir a S3 con cifrado:
Ventana de terminal npx @capgo/cli@latest bundle upload \--s3-region us-west-2 \--s3-apikey YOUR_ACCESS_KEY \--s3-apisecret YOUR_SECRET_KEY \--s3-bucket-name your-app-bundles \--iv-session-key IV_SESSION_KEY_FROM_STEP_2 \--channel Production
Consideraciones de seguridad
Sección titulada “Consideraciones de seguridad”Cuando utilices almacenamiento personalizado, considera estas mejores prácticas de seguridad:
Control de acceso
Sección titulada “Control de acceso”- Asegúrate de que las URL de almacenamiento sean accesibles para tus usuarios de la aplicación, pero no descubribles públicamente
- Utiliza URLs firmadas o autenticación basada en tokens cuando sea posible
- Implementa encabezados CORS adecuados para aplicaciones web
Cifrado
Sección titulada “Cifrado”- Siempre cifra los bundles sensibles utilizando las herramientas de cifrado Capgo
- Almacena las claves de cifrado de manera segura y rotarlas regularmente
- Utiliza HTTPS para todas las URL de bundles (requerido para aplicaciones móviles y Electron)
Monitoreo
Sección titulada “Monitoreo”- Monitorea los registros de acceso para detectar patrones de descarga inusuales
- Configura alertas para descargas de bundles fallidas
- Audita regularmente tus permisos de almacenamiento
Solución de problemas
Sección titulada “Solución de problemas”Problemas comunes
Sección titulada “Problemas comunes”No se está descargando el paquete:
- Verifique que la URL sea accesible públicamente y utilice HTTPS (requerido para aplicaciones móviles y Electron)
- Verifique los encabezados CORS para aplicaciones web
- Asegúrese de que el formato del paquete sea correcto
Errores de cifrado:
- Verifique que
ivSessionKeycoincida con el paquete cifrado - Verifique que el paquete se haya cifrado con la clave correcta
- Asegúrese de que se utilice la cifrado v2 para nuevos paquetes
Fallas al subir a S3:
- Verifique sus credenciales y permisos de S3
- Verifique las políticas de contenedor y la configuración CORS
- Asegúrese de que la región especificada sea correcta
Comandos de depuración
Sección titulada “Comandos de depuración”Verificar el estado del paquete:
npx @capgo/cli@latest app debugVerificar la integridad del paquete:
npx @capgo/cli@latest bundle listPasos siguientes
Sección titulada “Pasos siguientes”- Aprenda sobre Canales para administrar diferentes entornos de despliegue
- Explora Actualizar comportamiento para personalizar cómo se aplican las actualizaciones
- Configura Integración CI/CD para automatizar tu flujo de trabajo de almacenamiento personalizado
Sigue adelante desde Almacenamiento Personalizado
Sección titulada “Sigue adelante desde Almacenamiento Personalizado”Si estás utilizando Almacenamiento Personalizado para planificar la seguridad y la conformidad, conecte con Cifrado para el detalle de implementación en Cifrado, Conformidad para el detalle de implementación en Conformidad, Capgo Escáner de Seguridad para el flujo de trabajo del producto en Capgo Escáner de Seguridad, Capgo Seguridad para el flujo de trabajo del producto en Capgo Seguridad, y Capgo Centro de Confianza para el flujo de trabajo del producto en Capgo Centro de Confianza.