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.

Benutzerdefinierte Speicherung in Capgo funktioniert, indem Sie Ihr Bundle an einen externen Ort hochladen und Capgo die URL mitteilen, über die es abgerufen werden kann. Die Capgo SDK laden dann Updates direkt aus Ihrem benutzerdefinierten Speicherort und nicht aus Capgo’s Standard-Cloud-Speicher.

Der einfachste Weg, benutzerdefinierte Speicherung zu verwenden, besteht darin, Ihr Bundle an jede öffentlich zugängliche URL hochzuladen und diese URL Capgo bereitzustellen.

Grundlegender externer URL-Upload

Terminal-Fenster
Zur Zwischenablage kopieren
npx @capgo/cli@latest bundle upload --external https://your-domain.com/bundles/v1.2.3.zip

This command tells Capgo to reference the bundle at the specified URL instead of uploading it to Capgo’s cloud storage.

Terminal-Fenster

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

Capgo bietet eine integrierte Unterstützung für Amazon S3 und S3-kompatible Speicherdienste. CLI kann Ihre Bundle automatisch auf S3 hochladen und Capgo so konfigurieren, dass es die S3-URL verwendet.

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

Für S3-kompatible Dienste oder benutzerdefinierte Endpunkte:

Terminal-Fenster
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
ParameterBeschreibungErforderlich
--s3-regionAWS-Region für Ihren S3-BucketJa
--s3-apikeyS3-Zugriffschlüssel-IDJa
--s3-apisecretS3-SchlüsselzufahrtschlüsselJa
--s3-bucket-nameName Ihres S3-OrdnersJa
--s3-endpointBenutzerdefinierter S3-Endpunkt-URLNein
--s3-portPort für S3-EndpunktNein
--no-s3-sslSSL für S3-Upload deaktivierenNein

Wenn Sie benutzerdefinierte Speicher verwenden, insbesondere mit Verschlüsselung, müssen Sie Ihre Bundel ordnungsgemäß vorbereiten. Dazu gehört die Erstellung eines Zip-Ordners und gegebenenfalls dessen Verschlüsselung.

Erstelle zunächst ein Zip-Datei Ihres App-Paketes:

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

Die Zip-Befehlsausgabe enthält den Prüfsummenwert der Zip-Datei. Sie können diesen Wert verwenden, um die Zip-Datei zu verschlüsseln, wenn erforderlich. Verwenden Sie die Option, um eine strukturierte Ausgabe einschließlich der Prüfsumme zu erhalten. --json Terminal-Fenster

Zur Vervollständigung in die Zwischenablage kopieren

Option
Beschreibung
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
Terminal-FensterZur Vervollständigung in die Zwischenablage kopieren
--pathPfad zum Ordner zum Komprimieren (Standardwert: webDir aus capacitor.config)
--bundleBundle-Version-Nummer zur Namensgebung des Zip-Dateis
--nameBenutzerdefinierter Name für das Zip-Datei
--jsonAusgabeergebnisse in JSON-Format (enthält Prüfsumme)
--no-code-checkÜberspringen der Überprüfung auf notifyAppReady()-Aufruf und Indexdatei
--key-v2Verwendung von Verschlüsselung v2
--package-jsonPfade zu package.json-Dateien für monorepos (getrennt durch Komma)

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 Parameter ist erforderlich und sollte der Prüfsumme Ihres Zip-Dateis sein. Sie können die Prüfsumme aus dem Ausgabe des zip-Befehls (benutzen Sie die CHECKSUM Option für strukturierte Ausgabe). --json Standardmäßig wird der Verschlüsselungsbefehl Ihre lokale private Signierungsdatei verwenden. Sie können eine benutzerdefinierte Datei mit der

oder --key Option angeben. --key-data Der Verschlüsselungsbefehl wird die

erforderlich für den Upload oder die Entschlüsselung. ivSessionKey Verschlüsselungsbefehlsoptionen

Abschnitt mit dem Titel “Verschlüsselungsbefehlsoptionen”

Option
BeschreibungParameter ist erforderlich und sollte die Prüfsumme Ihres Zip-Dateis sein. Sie können die Prüfsumme aus dem Ausgabe des zip-Befehls (benutzen Sie die --output für strukturierte Ausgabe).
zipPathPfad zum zip-Datei zum Verschlüsseln (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 Signierungsdatei-Daten direkt (optional)
--jsonErgebnisse in JSON-Format ausgeben
  1. Deine App erstellen:

    Terminal-Fenster
    npm run build
  2. Eine Zip-Bundle erstellen:

    Terminal-Fenster
    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. Das Bundle verschlüsseln:

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

    Beachten Sie ivSessionKey aus der Ausgabe.

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

  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. Bauen Sie Ihr App:

    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 zippen:

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

    Terminalfenster
    npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM
  3. Mit Verschlüsselung 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 \
    --iv-session-key IV_SESSION_KEY_FROM_STEP_2 \
    --channel Production

Wenn Sie benutzerdefinierte Speicher verwenden, sollten Sie diese Sicherheitshinweise berücksichtigen:

  • Stellen Sie sicher, dass Ihre Speicher-URLs für Ihre App-Benutzer zugänglich sind, aber nicht öffentlich auffindbar sind
  • Verwenden Sie bei Bedarf signierte URLs oder Token-basierte Authentifizierung
  • Implementieren Sie korrekte CORS-Header für Web-basierte Apps
  • Sensible Bundles immer mit den Capgo Verschlüsselungstools verschlüsseln
  • Sichere Speicherung und regelmäßige Rotation von Verschlüsselungsschlüsseln
  • Verwenden Sie HTTPS für alle Bundle-URLs (erforderlich für mobile und Electron-Anwendungen)
  • Zugriffsprotokolle überwachen, um ungewöhnliche Downloadmuster zu erkennen
  • Benachrichtigungen für fehlgeschlagene Bundle-Downloads einrichten
  • Regelmäßige Überprüfung von Speicherberechtigungen

Bundle nicht herunterladen:

  • Stellen Sie sicher, dass 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:

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

S3-Upload-Fehler:

  • Ü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

Überprüfen Sie den Status des Bundles:

Terminal-Fenster
npx @capgo/cli@latest app debug

Überprüfen Sie die Integrität des Bundles:

Terminal-Fenster
npx @capgo/cli@latest bundle list
  • Machen Sie sich mit … vertraut Kanäle um verschiedene Bereitstellungsumgebungen zu verwalten
  • Erkunden Updateverhalten um zu konfigurieren, wie Updates angewendet werden
  • Einrichten 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 für die Implementierungsdetails in Verschlüsselung Kongruenz für die Implementierungsdetails in Kongruenz Capgo Sicherheits-Scanner für den Produktworkflow in Capgo Sicherheits-Scanner Capgo Sicherheit für den Produktworkflow in Capgo Sicherheit, und Capgo Trust Center für den Produktworkflow in Capgo Trust Center.