Zum Inhalt springen

Custom Storage

Capgo unterstützt benutzerdefinierte Speichersysteme für Ihre App-Bundles, sodass Sie Ihre Updates auf Ihrer eigenen Infrastruktur oder auf Diensten Dritter hosten können. Dies ist insbesondere nützlich für Organisationen mit spezifischen Sicherheitsanforderungen, Compliance-Anforderungen oder bestehender Speichereinrichtungen.

Übersicht

Übersicht

Custom storage in Capgo works by uploading your bundle to an external location and providing Capgo with the URL to access it. The Capgo SDK will then download updates directly from your custom storage location instead of Capgo’s default cloud storage.

Kostenoptimierung für große Bundle-Größen

Benutzerdefinierte URL-Hochladen

Capgo-Sektion: Benutzerdefinierte URL-Hochladen

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

Diese Kommando sagt Capgo, anstatt das Bundle auf Capgo’s Cloudspeicher hochzuladen, soll sich auf das Bundle an der angegebenen URL beziehen.

Für sicheres externes Speicher, können Sie Ihr Bundle verschlüsseln und die Entschlüsselungsschlüssel bereitstellen:

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

Capgo provides built-in support for Amazon S3 and S3-compatible storage services. The CLI can automatically upload your bundle to S3 and configure Capgo to use the S3 URL.

__CAPGO_KEEP_1__ kann Ihre Bundle automatisch auf S3 hochladen und __CAPGO_KEEP_2__ konfigurieren, um die S3-URL zu verwenden.

S3-Upload-Optionen
Abschnitt mit dem Titel „S3-Upload-Optionen“
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

In die Zwischenablage kopieren

Vollständige S3-Konfiguration

Abschnitt mit dem Titel „Vollständige S3-Konfiguration“

Für S3-kompatible Dienste oder benutzerdefinierte Endpunkte:
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

In die Zwischenablage kopieren

S3-Konfigurationsparameter
ParameterBeschreibungErforderlich
--s3-region__CAPGO_KEEP_0__ für Ihren S3-BucketJa
--s3-apikey__CAPGO_KEEP_0__-S3-Zugriffsschlüssel-IDJa
--s3-apisecret__CAPGO_KEEP_0__-S3-SchlüsselJa
--s3-bucket-nameName Ihres S3-BucketsJa
--s3-endpointBenutzerdefinierter S3-Endpunkt-URLNein
--s3-portPort für S3-EndpunktNein
--no-s3-sslSSL für S3-Upload deaktivierenNein

Wenn Sie eine benutzerdefinierte Speicherung verwenden, insbesondere mit Verschlüsselung, müssen Sie Ihre Bundel ordnungsgemäß vorbereiten. Dazu gehört die Erstellung eines Zip-Datei und optional deren Verschlüsselung.

Erstellen Sie zunächst eine Zip-Datei Ihres App-Bundles:

Terminalfenster
npx @capgo/cli@latest bundle zip com.example.app --path ./dist

Die Kommandozeile wird den Prüfsummenwert des Zip-Dateis zurückgeben. Sie können diese Prüfsumme verwenden, um das Zip-Datei zu verschlüsseln, wenn erforderlich. Verwenden Sie die --json Option, um eine strukturierte Ausgabe einschließlich der Prüfsumme zu erhalten.

Terminal-Fenster
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
OptionBeschreibung
--pathPfad zum Ordner, der komprimiert werden soll (Standardwert: webDir aus capacitor.config)
--bundleBundle-Version-Nummer zur Namensgebung des Zip-Dateis
--nameBenutzerdefinierter Name für das Zip-Datei
--jsonErgebnisse in JSON-Format (enthält Prüfsumme)
--no-code-checkÜberprüfung der notifyAppReady()-Aufruf und Indexdatei auslassen
--key-v2Verschlüsselung v2 verwenden
--package-jsonPfade zu package.json-Dateien für Monorepos (getrennt durch Komma)

Schritt 2: Das Bundle verschlüsseln (Optional)

Schritt 2: Das Bundle verschlüsseln (Optional)

Für eine erhöhte Sicherheit verschlüsseln Sie Ihr Zip-Bundle vor dem Hochladen:

Terminal-Fenster
# 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"

Der CHECKSUM ist erforderlich und sollte die Prüfsumme Ihres Zip-Datei sein. Sie können die Prüfsumme aus der Ausgabe der zip-Kommandozeile (verwenden Sie --json Option für strukturierte Ausgabe)

Standardmäßig wird der Verschlüsselungsbefehl Ihre lokale private Signierungsdatei verwenden. Sie können eine benutzerdefinierte Datei mithilfe der --key oder --key-data Optionen.

Der Verschlüsselungsbefehl gibt die ivSessionKey zurück, die zum Hochladen oder zur Entschlüsselung erforderlich sind.

OptionBeschreibung
zipPathPfad zur zip-Datei, die verschlüsselt werden soll (erforderlich)
checksumPrüfsumme der zip-Datei (erforderlich) - erhalten Sie sie mit dem zip-Befehl
--keyBenutzerdefinierter Pfad für die private Signierungsdatei (optional, verwendet lokale Datei standardmäßig)
--key-dataPrivate Schlüsseldaten direkt (optional)
--jsonErgebnisse in JSON-Format ausgeben
  1. Ihre App erstellen:

    Terminalfenster
    npm run build
  2. Erstelle einen Zip-Bundle:

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

    Beachten Sie den von diesem Befehl zurückgegebenen Prüfsummenwert.

  3. Verschlüssle das Bundle:

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

    Beachten Sie den ivSessionKey aus der Ausgabe.

  4. Hochladen auf Ihr Speicher: Laden Sie das verschlüsselte Zip-Datei auf Ihrem Hosting-Dienst hoch.

  5. Registrieren Sie sich bei Capgo:

    Terminalfenster
    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. Ihre App erstellen:

    Terminalfenster
    npm run build
  2. Direkt auf S3 hochladen:

    Terminalfenster
    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. Bauen und komprimieren:

    Terminal-Fenster
    npm run build
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2
  2. Das Bundle verschlüsseln:

    Terminal-Fenster
    npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM
  3. Mit Verschlüsselung auf S3 hochladen:

    Terminal-Fenster
    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

Sicherheitsüberlegungen

Sicherheitsüberlegungen

Wenn Sie benutzerdefinierte Speicher verwenden, beachten Sie diese Sicherheitshinweise:

  • Verwenden Sie bei Bedarf signierte URLs oder Token-basierte Authentifizierung
  • Implementieren Sie korrekte CORS-Header für webbasierte Apps
  • Verschlüsselung

Verschlüsseln Sie immer sensible Pakete mit den __CAPGO_KEEP_0__-Verschlüsselungstools

Speichern Sie Verschlüsselungsschlüssel sicher und rotieren Sie sie regelmäßig
  • Always encrypt sensitive bundles using the Capgo encryption tools
  • Zugriffssteuerung
  • Sicherheitsüberlegungen
  • Überwachung der Zugriffsprotokolle, um ungewöhnliche Herunterlademuster zu erkennen
  • Einrichten von Warnungen für fehlgeschlagene Bundle-Downloads
  • Regelmäßige Überprüfung der Speicherberechtigungen

Bundle wird nicht heruntergeladen:

  • Überprüfen Sie, ob die URL öffentlich zugänglich und über HTTPS (erforderlich für mobile und Electron-Anwendungen) ist
  • Überprüfen Sie die CORS-Kopfzeilen für Web-Anwendungen
  • Stellen Sie sicher, dass die Bundle-Formatierung korrekt ist

Verschlüsselungsfehler:

  • Überprüfen Sie das ivSessionKey passt zum verschlüsselten Bundle
  • Überprüfen Sie, ob das Bundle mit der richtigen Schlüssel verschlüsselt wurde
  • Stellen Sie sicher, dass für neue Bundle die Verschlüsselung v2 verwendet wird

S3-Uploadfehler:

  • Überprüfen Sie Ihre S3-Zugangsdaten und Berechtigungen
  • Überprüfen Sie die Bucket-Politik und die CORS-Konfiguration
  • Stellen Sie sicher, dass die angegebene Region korrekt ist

Bündelstatus überprüfen:

Terminalfenster
npx @capgo/cli@latest app debug

Bündelintegrität überprüfen:

Terminalfenster
npx @capgo/cli@latest bundle list
  • Mehr über Kanäle um verschiedene Bereitstellungsumgebungen zu verwalten
  • Entdecken Updateverhalten um zu ändern, wie Updates angewendet werden
  • Einstellungen CI/CD-Integration um Ihre benutzerdefinierte Speicherablaufautomatisieren

Wenn Sie Custom Storage verwenden Custom Storage um Sicherheit und Compliance zu planen, verbinden Sie es mit Verschlüsselung Verschlüsselung, für die Implementierungsdetails in Verschlüsselung, Konzformität für die Implementierungsdetails in Konzformität, Capgo Sicherheits-Scanner für den Produktworkflow in Capgo Sicherheits-Scanner, Capgo Sicherheit für den Produktworkflow in Capgo Sicherheit, und Capgo Vertrauenszentrum für den Produktworkflow in Capgo Vertrauenszentrum.