__CAPGO_KEEP_1__
Copie un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
Configuración de credenciales de compilación para iOS y Android
Resumen
Sección titulada “Resumen”Capgo CLI almacena tus credenciales de compilación en tu máquina — nunca en los servidores de Capgo. Por defecto, viven en un archivo global, compartido por todos tus proyectos. Puedes pasar ~/.capgo-credentials/credentials.jsonpara mantenerlas --local por proyecto en en lugar de eso. Cuando ejecutes una compilación, las credenciales guardadas se utilizan automáticamente y se envían de manera segura a __CAPGO_KEEP_0__, luego se eliminan después de que se complete la compilación. .capgo-credentials.json instead. When you run a build, the saved credentials are used automatically and sent securely to Capgo, then deleted after the build completes.
Comandos
Sección titulada “Comandos”Administrar credenciales de manera interactiva
Sección titulada “Administrar credenciales de manera interactiva”La forma más rápida de trabajar con sus credenciales guardadas es el administrador interactivo. Abre una IU de terminal (la misma que build init usa) donde puede navegar por lo que se almacena, ver qué está configurado por aplicación y plataforma, exportar un archivo listo para CI/CD, .env o eliminar las credenciales de una plataforma:
bunx @capgo/cli@latest build credentials manage| Opción | Descripción |
|---|---|
--appId <appId> | Aplicación para administrar (te pide que elijas si se omite) |
--platform <ios|android> | Plataforma para administrar (solicita si se omite) |
--local | Utilice el archivo por proyecto .capgo-credentials.json en lugar del archivo global |
Preferir comandos de una sola ejecución, scriptables? Utilice los comandos individuales a continuación.
Guardar credenciales
Título de la sección “Guardar credenciales”Almacene sus credenciales de compilación localmente para su uso automático:
bunx @capgo/cli@latest build credentials save --platform <ios|android> [options]Actualizar credenciales
Título de la sección “Actualizar credenciales”Actualizar credenciales existentes parcialmente sin re-proveer todo:
bunx @capgo/cli@latest build credentials update --platform <ios|android> [options]La update El comando utiliza la fusión aditiva para los perfiles de configuración — los nuevos perfiles se fusionan con los existentes. Para reemplazar la totalidad del mapa de configuración en su lugar, agregue --overwrite-ios-provisioning-map.
Ejemplo — agregar un perfil de extensión a las credenciales existentes:
bunx @capgo/cli@latest build credentials update \ --platform ios \ --ios-provisioning-profile "com.example.app.widget=./widget_profile.mobileprovision"El comando de actualización acepta las mismas opciones que save pero todas son opcionales — solo los campos que proporciona se actualizan.
Lista de credenciales
Sección titulada “Listar credenciales”Ver credenciales guardadas actualmente (las contraseñas están ocultas):
bunx @capgo/cli@latest build credentials list
# List credentials for a specific appbunx @capgo/cli@latest build credentials list --appId com.example.appBorrar credenciales
Sección titulada “Borrar credenciales”Eliminar credenciales guardadas de tu máquina local:
# Clear all credentialsbunx @capgo/cli@latest build credentials clear
# Clear credentials for a specific app + platformbunx @capgo/cli@latest build credentials clear --appId com.example.app --platform iosMigrar credenciales
Sección titulada “Migrar credenciales”Convertir formato de legado de un solo perfil al nuevo formato de multi-destino:
bunx @capgo/cli@latest build credentials migrate --platform iosEl comando de migración detecta credenciales antiguas BUILD_PROVISION_PROFILE_BASE64 , las convierte a CAPGO_IOS_PROVISIONING_MAP, y elimina las claves de legado. Consulte Migración desde un perfil único para obtener más detalles.
Guardar credenciales de iOS
Sección titulada “Guardar credenciales de iOS”Ejemplo Completo
Sección titulada “Ejemplo Completo”bunx @capgo/cli@latest build credentials save \ --platform ios \ --certificate ./cert.p12 \ --p12-password "YourP12Password" \ --ios-provisioning-profile "com.example.app=./profile.mobileprovision" \ --apple-key ./AuthKey_ABC1234567.p8 \ --apple-key-id "ABC1234567" \ --apple-issuer-id "00000000-0000-0000-0000-000000000000" \ --apple-team-id "TEAM123456"Opciones de iOS
Sección titulada “Opciones de iOS”| Opción | Descripción | Requerido |
|---|---|---|
--certificate <path> | Ruta al archivo de certificado .p12 | Sí (versión de lanzamiento) |
--p12-password <password> | Contraseña para el certificado .p12 | Sí (versión de lanzamiento) |
--ios-provisioning-profile <mapping> | Provisioning de perfil de configuración (bundleId=path). Repetible para aplicaciones con múltiples objetivos. Si solo hay un perfil y no hay prefijo bundleId, CLI se infiere automáticamente desde el perfil. | Sí (versión de lanzamiento) |
--apple-key <path> | Ruta a App Store Connect API .p8 clave | Vea la nota¹ |
--apple-key-id <id> | App Store Connect API Identificador de clave | Vea la nota¹ |
--apple-issuer-id <id> | App Store Connect API Identificador del emisor (UUID) | Vea nota¹ |
--apple-team-id <id> | ID del equipo de App Store Connect | Sí |
--ios-distribution <mode> | Modo de distribución: app_store (predeterminado) o ad_hoc | No |
--output-upload | Habilitar un enlace de descarga temporal Capgo para el artefacto de compilación | No (predeterminado: false) |
--output-retention <seconds> | ¿Cuánto tiempo mantener los resultados de compilación (por ejemplo. 3600s) | No (predeterminado: 3600s) |
--skip-build-number-bump | Saltar el incremento automático del número de compilación | No |
¿Qué se almacena?
Sección titulada “¿Qué se almacena?”Cuando guardas credenciales de iOS, el CLI:
- Lee los archivos de certificado y perfil de provisión
- Los convierte a codificación base64
- Los almacena en
~/.capgo-credentials/credentials.json(o.capgo-credentials.jsoncon--local) - Almacena contraseñas e IDs como texto plano (solo archivos locales)
La estructura del archivo almacenado:
{ "ios": { "BUILD_CERTIFICATE_BASE64": "...", "CAPGO_IOS_PROVISIONING_MAP": "{\"com.example.app\":{\"profile\":\"...\",\"name\":\"match AppStore com.example.app\"}}", "APPLE_KEY_CONTENT": "...", "P12_PASSWORD": "...", "APPLE_KEY_ID": "ABC1234567", "APPLE_ISSUER_ID": "...", "APP_STORE_CONNECT_TEAM_ID": "TEAM123456", "CAPGO_IOS_DISTRIBUTION": "app_store" }}Almacenando credenciales de Android
Sección titulada “Almacenando credenciales de Android”Ejemplo completo
Sección titulada “Ejemplo completo”bunx @capgo/cli@latest build credentials save \ --platform android \ --keystore ./release.keystore \ --keystore-alias "my-key-alias" \ --keystore-key-password "KeyPassword123" \ --keystore-store-password "StorePassword123" \ --play-config ./play-store-service-account.jsonOpciones de Android
Sección titulada “Opciones de Android”| Opción | Descripción | Requerido |
|---|---|---|
--keystore <path> | Ruta al archivo .keystore o .jks | Sí (versión de lanzamiento) |
--keystore-alias <alias> | Alias de clave en el keystore | Sí (versión de lanzamiento) |
--keystore-key-password <password> | Contraseña para el alias de clave | Sí (versión de lanzamiento) |
--keystore-store-password <password> | Contraseña para el keystore | Sí (lanzamiento) |
--play-config <path> | Ruta del archivo JSON de servicio de Play Store | Sí (envío) |
¿Qué se almacena?
Sección titulada “¿Qué se almacena?”Cuando guardas credenciales de Android, el CLI:
- Lee los archivos del keystore y del servicio de JSON
- Los convierte a codificación base64
- Los almacena en
~/.capgo-credentials/credentials.json(o.capgo-credentials.jsoncon--local) - Almacena contraseñas y alias como texto plano (solo archivos locales)
La estructura del archivo almacenado:
{ "android": { "ANDROID_KEYSTORE_FILE": "...", "PLAY_CONFIG_JSON": "...", "KEYSTORE_KEY_ALIAS": "my-key-alias", "KEYSTORE_KEY_PASSWORD": "...", "KEYSTORE_STORE_PASSWORD": "..." }}Usando credenciales guardadas
Sección titulada “Usando credenciales guardadas”Una vez que hayas guardado credenciales, se utilizan automáticamente cuando construyes:
# Credentials automatically loaded from ~/.capgo-credentials/credentials.jsonbunx @capgo/cli@latest build request com.example.app --platform iosTambién puedes sobreescribir credenciales guardadas utilizando variables de entorno:
# Environment variables take precedence over saved credentialsBUILD_CERTIFICATE_BASE64="..." \P12_PASSWORD="different-password" \bunx @capgo/cli@latest build request com.example.app --platform iosOrden de precedencia:
- Variables de entorno (prioridad más alta)
- Credenciales guardadas (
~/.capgo-credentials/credentials.json, o local).capgo-credentials.json) - Sin credenciales (prioridad más baja)
Ver credenciales guardadas
Sección titulada “Ver credenciales guardadas”Muestra las credenciales que has guardado:
bunx @capgo/cli@latest build credentials listEjemplo de salida:
📋 Saved Build Credentials:
iOS Credentials: ✓ Certificate (base64) ✓ Provisioning Map (JSON) ✓ Apple Key Content (base64) ✓ P12 Password: ******** ✓ Apple Key ID: ABC1234567 ✓ Apple Issuer ID: 00000000-0000-0000-0000-000000000000 ✓ Team ID: TEAM123456
Android Credentials: ✓ Keystore (base64) ✓ Play Store Config (base64) ✓ Keystore Alias: my-key-alias ✓ Key Password: ******** ✓ Store Password: ********
Location: ~/.capgo-credentials/credentials.json
🔒 These credentials are stored locally on your machine only. When building, they are sent to Capgo but NEVER stored there. They are auto-deleted after build completion.Prácticas recomendadas de seguridad
Sección titulada “Prácticas de Seguridad”Seguridad de Almacenamiento Local
Sección titulada “Seguridad de Almacenamiento Local”-
Permisos de Archivo
Ventana de Terminal # Global credentials directory + filechmod 700 ~/.capgo-credentialschmod 600 ~/.capgo-credentials/credentials.json# Local (per-project) credentials, if you use --localchmod 600 .capgo-credentials.json -
Nunca Compartir Credenciales
Ventana de Terminal # Ignore the per-project credentials file (used with --local)echo ".capgo-credentials.json" >> .gitignoreEl archivo global vive en tu directorio de inicio, fuera del repositorio.
-
Credenciales Separadas
- Usar credenciales diferentes para desarrollo local vs CI/CD
- Rotar credenciales con regularidad
- No compartir credenciales entre miembros del equipo
Uso de CI/CD
Sección titulada “Uso de CI/CD”Para entornos de CI/CD, prefiere variables de entorno antes que credenciales guardadas.
Exportar un archivo .env listo para usar .env (recomendado)
Sección titulada “Exportar un archivo .env listo para usar (recomendado)”En lugar de codificar en base64 cada archivo de credenciales a mano (ver abajo), deja build credentials manage generar el archivo para ti:
bunx @capgo/cli@latest build credentials manage# pick your app → choose "Export to .env"Escribe un .env.capgo.<appId>.<platform> archivo (permisos 0600) que contiene cada credencial guardada como una variable de entorno — cada línea es un secreto para agregar a tu proveedor CI/CD. Por defecto, se combinan ambas plataformas; agrega --platform ios o --platform android para limitarlo a una.
Referencia completa de variables de entorno
Sección titulada “Referencia completa de variables de entorno”El CLI lee las siguientes variables de entorno para credenciales:
Credenciales de iOS:
| Variable | Descripción | Formato | Requerido |
|---|---|---|---|
BUILD_CERTIFICATE_BASE64 | Certificado P12/PKCS12 para firmar code | Base64 | Sí (lanzamiento) |
CAPGO_IOS_PROVISIONING_MAP | Mapa JSON de IDs de paquetes a datos de perfil de provisión | Cadena de JSON | Sí (lanzamiento) |
P12_PASSWORD | Contraseña para el certificado P12 | Texto plano | Opcional |
APPLE_KEY_ID | Clave de App Store Connect API ID de clave | Cadena de texto (por ejemplo, “ABC1234567”) | Vea la nota¹ |
APPLE_ISSUER_ID | Clave de App Store Connect API ID de emisor | Cadena de UUID | Vea la nota¹ |
APPLE_KEY_CONTENT | App Store Connect API clave (.p8 archivo de contenido) | Base64 | Ver nota¹ |
APP_STORE_CONNECT_TEAM_ID | ID de equipo de desarrollador de Apple | String (por ejemplo, “XXXXXXXXXX”) | Sí |
CAPGO_IOS_DISTRIBUTION | Modo de distribución: app_store (por defecto) o ad_hoc | String | No |
Credenciales de Android:
| Variable | Descripción | Formato | Requerido |
|---|---|---|---|
ANDROID_KEYSTORE_FILE | Archivo de keystore para firmar APK/AAB | Base64 | Sí (lanzamiento) |
KEYSTORE_KEY_ALIAS | Alias de clave dentro del keystore | Cadena de texto | Sí (lanzamiento) |
KEYSTORE_KEY_PASSWORD | Contraseña para el alias de clave | Texto plano | Sí* |
KEYSTORE_STORE_PASSWORD | Contraseña para el archivo del keystore | Texto plano | Sí* |
PLAY_CONFIG_JSON | Archivo JSON de la cuenta de servicios de Google Play | Base64 | Sí (envío) |
*Si se proporciona solo una contraseña, se utilizará para ambos KEYSTORE_KEY_PASSWORD y KEYSTORE_STORE_PASSWORD.
GitHub Ejemplo de acciones
Sección titulada “GitHub Ejemplo de acciones”name: Cloud Build
on: push: branches: [main]
jobs: build-ios: runs-on: ubuntu-latest steps: - uses: actions/checkout@v6 - uses: oven-sh/setup-bun@v2 - run: bun install - run: bunx @capgo/cli@latest build request com.example.app --platform ios env: CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }} BUILD_CERTIFICATE_BASE64: ${{ secrets.BUILD_CERTIFICATE_BASE64 }} CAPGO_IOS_PROVISIONING_MAP: ${{ secrets.CAPGO_IOS_PROVISIONING_MAP }} P12_PASSWORD: ${{ secrets.P12_PASSWORD }} APPLE_KEY_ID: ${{ secrets.APPLE_KEY_ID }} APPLE_ISSUER_ID: ${{ secrets.APPLE_ISSUER_ID }} APPLE_KEY_CONTENT: ${{ secrets.APPLE_KEY_CONTENT }} APP_STORE_CONNECT_TEAM_ID: ${{ secrets.APP_STORE_CONNECT_TEAM_ID }}
build-android: runs-on: ubuntu-latest steps: - uses: actions/checkout@v6 - uses: oven-sh/setup-bun@v2 - run: bun install - run: bunx @capgo/cli@latest build request com.example.app --platform android env: CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }} ANDROID_KEYSTORE_FILE: ${{ secrets.ANDROID_KEYSTORE_FILE }} KEYSTORE_KEY_ALIAS: ${{ secrets.KEYSTORE_KEY_ALIAS }} KEYSTORE_KEY_PASSWORD: ${{ secrets.KEYSTORE_KEY_PASSWORD }} KEYSTORE_STORE_PASSWORD: ${{ secrets.KEYSTORE_STORE_PASSWORD }} PLAY_CONFIG_JSON: ${{ secrets.PLAY_CONFIG_JSON }}Preparando valores Base64
Sección titulada “Preparando valores Base64”Para convertir tus archivos de credenciales a base64 para secretos de CI/CD:
# iOS Certificate (.p12)base64 -i certificate.p12 | tr -d '\n' > certificate_base64.txt
# iOS Provisioning Profiles — use the CLI to generate CAPGO_IOS_PROVISIONING_MAP:bunx @capgo/cli@latest build credentials save --platform ios \ --ios-provisioning-profile "com.example.app=./profile.mobileprovision" \ # ... other options# Then copy CAPGO_IOS_PROVISIONING_MAP from ~/.capgo-credentials/credentials.json to your CI secrets
# iOS App Store Connect Key (.p8)base64 -i AuthKey_XXXXXX.p8 | tr -d '\n' > apple_key_base64.txt
# Android Keystore (.keystore or .jks)base64 -i release.keystore | tr -d '\n' > keystore_base64.txt
# Google Play Service Account JSONbase64 -i play-store-service-account.json | tr -d '\n' > play_config_base64.txt¿Por qué las variables de entorno son más seguras?
Sección titulada “¿Por qué las variables de entorno son más seguras?”Esta aproximación es más segura porque:
- Los secretos se gestionan por tu plataforma CI/CD
- No hay archivos de credenciales en ejecutores
- Rotación y control de acceso fácil
- Huellas de auditoría para el uso de secretos
Rotación de credenciales
Sección titulada “Rotación de credenciales”Rota tus credenciales regularmente:
- iOS: Genera nuevos certificados y API claves anualmente
- Android: Cambia las contraseñas de keystore anualmente
- Después de cambios en el equipoRotar cuando los miembros del equipo dejen
Actualizar credenciales guardadas:
# Re-run save command with new credentialsbunx @capgo/cli@latest build credentials save --platform ios --certificate ./new-cert.p12 ...Solución de problemas
Título de la sección “Solución de problemas”No se encontraron credenciales
Título de la sección “No se encontraron credenciales”Si el build dice que no se encontraron credenciales:
-
Compruebe si las credenciales están guardadas:
Ventana de terminal bunx @capgo/cli@latest build credentials list -
Guardar credenciales si faltan:
Ventana de terminal bunx @capgo/cli@latest build credentials save --platform ios ... -
Verificar que el archivo de credenciales existe:
Ventana de terminal ls -la ~/.capgo-credentials/credentials.json # globalls -la .capgo-credentials.json # local (--local)
“Denegado por permiso” al leer credenciales
Sección titulada ““Denegado por permiso” al leer credenciales”Corregir permisos de archivo:
chmod 600 ~/.capgo-credentials/credentials.json # globalchmod 600 .capgo-credentials.json # localNo se están utilizando las credenciales
Sección titulada “No se están utilizando las credenciales”Verifique que se ha especificado la plataforma correcta:
# Make sure --platform matches saved credentialsbunx @capgo/cli@latest build request com.example.app --platform ios # Uses ios credentialsbunx @capgo/cli@latest build request com.example.app --platform android # Uses android credentialsBorrar y volver a guardar las credenciales
Sección titulada “Borrar y volver a guardar las credenciales”Si las credenciales parecen estar dañadas:
# Clear all credentialsbunx @capgo/cli@latest build credentials clear
# Save againbunx @capgo/cli@latest build credentials save --platform ios ...Migración desde Variables de Entorno
Sección titulada “Migración desde Variables de Entorno”Si actualmente está utilizando variables de entorno, puede migrar a credenciales guardadas:
-
Extrae tus variables de entorno actuales
Ventana de terminal echo $BUILD_CERTIFICATE_BASE64 # Verify they exist -
Volver a codificar archivos base64 a sus archivos originales (si es necesario)
Ventana de terminal echo "$BUILD_CERTIFICATE_BASE64" | base64 -d > cert.p12echo "$BUILD_PROVISION_PROFILE_BASE64" | base64 -d > profile.mobileprovision -
Guardar utilizando el CLI
Ventana de terminal bunx @capgo/cli@latest build credentials save \--platform ios \--certificate ./cert.p12 \--ios-provisioning-profile ./profile.mobileprovision \--p12-password "$P12_PASSWORD" \--apple-key-id "$APPLE_KEY_ID" \--apple-issuer-id "$APPLE_ISSUER_ID" \--apple-team-id "$APP_STORE_CONNECT_TEAM_ID"Si tienes credenciales existentes guardadas en el formato antiguo (simple,
BUILD_PROVISION_PROFILE_BASE64ejecuta:Ventana de terminal bunx @capgo/cli@latest build credentials migrate --platform iosEsta convierte la legado de perfil único a un
CAPGO_IOS_PROVISIONING_MAPy elimina el viejoBUILD_PROVISION_PROFILE_BASE64yAPPLE_PROFILE_NAMEllaves. -
Prueba la compilación
Ventana de terminal bunx @capgo/cli@latest build request com.example.app --platform ios -
Eliminar variables de entorno (opcional)
Ventana de terminal unset BUILD_CERTIFICATE_BASE64 BUILD_PROVISION_PROFILE_BASE64
Ubicación del archivo
Sección titulada “Ubicación del archivo”Las credenciales se almacenan en un archivo JSON único:
- Global (por defecto):
~/.capgo-credentials/credentials.json— compartido en todos tus proyectos - Local (con
--local):.capgo-credentials.jsonen la raíz de tu proyecto — sobreescribe el archivo global para ese proyecto
El archivo se crea automáticamente la primera vez que guardas credenciales. Agrega .capgo-credentials.json a tu .gitignore Así, las credenciales por proyecto nunca se comiten.
Pasos siguientes
Sección titulada “Pasos siguientes”- Empezar - Crea tu primera compilación
- Compilaciones de iOS - Configuración de compilación específica de iOS
- Compilaciones de Android - Configuración de compilación específica de Android
- Solución de problemas - Problemas y soluciones comunes
Necesitas ayuda?
Título de la sección “¿Necesitas ayuda?”- 📚 Guía de solución de problemas
- 💬 Comunidad de Discord
- Correo electrónico: support@capgo.app
Sigue adelante desde la gestión de credenciales
Título de la sección “Sigue adelante desde la gestión de credenciales”Si estás utilizando Gestión de credenciales para planificar la automatización de CI/CD, conecta con Capgo CI/CD para el flujo de trabajo del producto en Capgo CI/CD Capgo Compilaciones nativas para el flujo de trabajo del producto en Capgo Compilaciones nativas, Capgo Integraciones para el flujo de trabajo del producto en Capgo Integraciones, Integración CI/CD para el detalle de implementación en Integración CI/CD, y GitHub Integración de Acciones para el detalle de implementación en GitHub Integración de Acciones.