Pular al contenido

Almacenamiento Personalizado

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 especialmente útil para organizaciones con requisitos de seguridad específicos, necesidades de cumplimiento o infraestructura de almacenamiento existente.

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.

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.

Ventana de terminal
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip

Este comando le dice a Capgo que refiera el paquete en la URL especificada en lugar de subirlo a Capgo’s almacenamiento en la nube.

Para almacenamiento externo seguro, puede cifrar su paquete y proporcionar las claves de descifrado:

Ventana de terminal
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip --iv-session-key YOUR_IV_SESSION_KEY

Capgo ofrece soporte integrado para Amazon S3 y servicios de almacenamiento S3 compatibles. CLI puede subir automáticamente su paquete a S3 y configurar Capgo para utilizar la URL de S3.

Ventana de terminal
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-name

Para servicios compatibles con S3 o puntos finales personalizados:

Ventana de terminal
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 SSL
ParámetroDescripciónRequerido
--s3-regionRegión de AWS para tu contenedor de S3
--s3-apikeyID de clave de acceso de S3
--s3-apisecretClave de acceso secreta de S3
--s3-bucket-nameNombre de tu contenedor S3
--s3-endpointURL de punto de conexión de S3 personalizadoNo
--s3-portPuerto para el punto de conexión de S3No
--no-s3-sslDeshabilitar SSL para la carga de S3No

Preparación de paquetes y cifrado

Preparación y cifrado de paquetes

Al utilizar almacenamiento personalizado, especialmente con cifrado, es necesario preparar adecuadamente sus paquetes. Esto implica crear un archivo zip y cifrarlo opcionalmente.

Paso 1: Crear un paquete zip

Paso 1: Crear un paquete zip

Primero, cree un archivo zip de su paquete de la aplicación:

Ventana de terminal
npx @capgo/cli@latest bundle zip com.example.app --path ./dist

El comando zip devolverá el checksum del archivo zip. Puede utilizar este checksum para cifrar el archivo zip si es necesario. Utilice la --json Opciones del comando Zip

Paso 1: Crear un paquete zip

Ventana de terminal
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ónDescripción
--pathRuta del folder para zip (por defecto webDir de capacitor.config)
--bundleNúmero de versión del paquete para nombrar el archivo zip
--nameNombre personalizado para el archivo zip
--jsonResultado de salida en formato JSON (incluye checksum)
--no-code-checkSaltarse la comprobación de la llamada a notifyAppReady() y el archivo de índice
--key-v2Usar cifrado v2
--package-jsonRutas de archivo package.json para repositorios monorepos (separadas por comas)

Para una mayor seguridad, cifre su archivo zip antes de subirlo:

Ventana de terminal
# Using default local key
npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM
# Using custom key file
npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key ./path/to/.capgo_key_v2
# Using key data directly
npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM --key-data "PRIVATE_KEY_CONTENT"

El CHECKSUM Este parámetro es obligatorio y debe ser el checksum de su archivo zip. Puede obtener el checksum del comando zip (utilice --json opción para salida estructurada).

Por defecto, el comando cifrar utilizará su clave privada de firma local. Puede especificar una clave personalizada utilizando los --key o --key-data opciones.

El comando cifrar devolverá el ivSessionKey necesario para la subida o la descifrado.

Opciones del comando de cifrado

Opción de comandos de comando de cifrado
OpciónDescripción
zipPathRuta del archivo zip a cifrar (obligatorio)
checksumChecksum del archivo zip (obligatorio) - obténlo del comando zip
--keyRuta personalizada para la clave de firma privada (opcional, utiliza la clave local por defecto)
--key-dataDatos de la clave de firma privada directamente (opcional)
--jsonResultado de salida en formato JSON
  1. Construye tu aplicación:

    ventana de terminal
    npm run build
  2. Crear un archivo zip:

    ventana de terminal
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --bundle 1.2.3

    Nota el checksum devuelto por este comando.

  3. Cifre el paquete:

    Ventana de terminal
    npx @capgo/cli@latest bundle encrypt ./com.example.app-1.2.3.zip CHECKSUM_FROM_STEP_2

    Tenga en cuenta que ivSessionKey desde la salida.

  4. Subir a su almacenamiento: Subir el archivo zip cifrado a su servicio de alojamiento.

  5. Registre 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
  1. Construye tu aplicación:

    ventana de terminal
    npm run build
  2. 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
  1. Construye y comprime:

    ventana de terminal
    npm run build
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2
  2. Cifra el paquete:

    Ventana de terminal
    npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM
  3. Cargar 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

Al utilizar almacenamiento personalizado, considere estas mejores prácticas de seguridad:

  • Asegúrese de que las URL de almacenamiento sean accesibles a los usuarios de su aplicación pero no descubribles públicamente
  • Utilice URLs firmadas o autenticación basada en tokens cuando sea posible
  • Implemente los encabezados CORS adecuados para aplicaciones web
  • Cifre siempre los paquetes sensibles utilizando las herramientas de cifrado Capgo
  • Almacene las claves de cifrado de manera segura y las rotule regularmente
  • Utilice HTTPS para todas las URL de paquetes (requerido para aplicaciones móviles y Electron)
  • Monitoree los registros de acceso para detectar patrones de descarga inusuales
  • Establezca alertas para descargas de paquetes fallidas
  • Audite regularmente las permisos de almacenamiento

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 ivSessionKey coincida 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

Fallos de carga en S3:

  • Verifica tus credenciales y permisos de S3
  • Revisa las políticas de contenedor y la configuración de CORS
  • Asegúrate de que la región especificada sea correcta

Verifica el estado del paquete:

Ventana de terminal
npx @capgo/cli@latest app debug

Verifica la integridad del paquete:

Ventana de terminal
npx @capgo/cli@latest bundle list
  • Aprende sobre Canales para gestionar 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