Lompat ke konten

Penyimpanan Kustom

Capgo mendukung solusi penyimpanan kustom untuk paket aplikasi Anda, memungkinkan Anda untuk menghosting update Anda di infrastruktur sendiri atau layanan penyimpanan pihak ketiga. Hal ini sangat berguna bagi organisasi dengan persyaratan keamanan tertentu, kebutuhan kompatibilitas, atau infrastruktur penyimpanan yang sudah ada.

Penyimpanan kustom di Capgo bekerja dengan mengunggah paket Anda ke lokasi eksternal dan memberikan Capgo dengan URL untuk mengaksesnya. Capgo SDK akan mengunduh update secara langsung dari lokasi penyimpanan kustom Anda daripada Capgo’s penyimpanan awan default.

Metode paling sederhana untuk menggunakan penyimpanan khusus adalah dengan mengunggah bundle Anda ke URL yang dapat diakses publik dan menyediakan URL tersebut kepada Capgo.

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

Perintah ini menginstruksikan Capgo untuk merujuk pada bundle di URL yang ditentukan daripada mengunggahnya ke penyimpanan awan Capgo.

Untuk penyimpanan luar yang aman, Anda dapat mengenkripsi bundle Anda dan menyediakan kunci dekripsi:

Jendela 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 menyediakan dukungan bawaan untuk penyimpanan Amazon S3 dan layanan penyimpanan S3 yang kompatibel. CLI dapat secara otomatis mengunggah bundle Anda ke S3 dan mengonfigurasi Capgo untuk menggunakan URL S3.

Jendela 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

Untuk layanan S3 yang kompatibel atau endpoint kustom:

Jendela 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
ParameterDeskripsiDiperlukan
--s3-regionWilayah AWS untuk bucket S3 AndaYa
--s3-apikeyID Kunci Akses S3Ya
--s3-apisecretKunci Sandi S3Ya
--s3-bucket-nameNama S3 bucket AndaYa
--s3-endpointURL endpoint S3 kustomTidak
--s3-portPort untuk endpoint S3Tidak
--no-s3-sslNonaktifkan SSL untuk unggah S3Tidak

Saat menggunakan penyimpanan kustom, terutama dengan enkripsi, Anda perlu mempersiapkan paket Anda dengan benar. Ini melibatkan membuat file zip dan secara opsional mengenkripsinya.

Pertama-tama, buatlah file zip dari bundle aplikasi Anda:

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

Perintah zip akan mengembalikan checksum dari file zip. Anda dapat menggunakan checksum ini untuk mengenkripsi file zip jika diperlukan. Gunakan --json untuk mendapatkan output terstruktur termasuk checksum.

Jendela terminal
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
PilihanDeskripsi
--pathPath ke folder untuk mengompres (default ke webDir dari capacitor.config)
--bundleNomor versi bundle untuk nama file zip
--nameNama khusus untuk file zip
--jsonHasil output dalam format JSON (termasuk ceklis)
--no-code-checkLebihkan memeriksa panggilan notifyAppReady() dan file index
--key-v2Pakai enkripsi v2
--package-jsonPath ke file package.json untuk repositori monorepo (dipisahkan dengan koma)

Untuk keamanan yang lebih tinggi, enkripsi bundle zip Anda sebelum mengunggah:

Jendela 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"

Parameter ini diperlukan dan harus merupakan cek tanda tangan dari file zip Anda. Anda dapat mendapatkan cek tanda tangan dari output perintah zip (gunakan CHECKSUM option untuk output terstruktur). --json Dengan default, perintah enkripsi akan menggunakan kunci pribadi penandatanganan lokal Anda. Anda dapat menentukan kunci khusus menggunakan

atau --key options. --key-data Perintah enkripsi akan mengembalikan

yang diperlukan untuk unggah atau dekripsi. ivSessionKey Pilihan Perintah Enkripsi

Bagian berjudul “Pilihan Perintah Enkripsi”

Pilihan
DeskripsiParameter ini diperlukan dan harus merupakan cek tanda tangan dari file zip Anda. Anda dapat mendapatkan cek tanda tangan dari output perintah zip (gunakan --output untuk output terstruktur).
zipPathRute ke file zip untuk dienkripsi (diperlukan)
checksumChecksum dari file zip (diperlukan) - dapatkan dari perintah zip
--keyRute khusus untuk kunci tanda tangan pribadi (opsional, menggunakan kunci lokal secara default)
--key-dataData kunci tanda tangan pribadi secara langsung (opsional)
--jsonHasil output dalam format JSON
  1. Buat aplikasi Anda:

    Jendela Terminal
    npm run build
  2. Buat bundle zip:

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

    Perhatikan checksum yang dikembalikan oleh perintah ini.

  3. Enkripsi bundle:

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

    Perhatikan hasilnya. ivSessionKey dari hasil output.

  4. Unggah ke penyimpanan Anda: Unggah file zip terenkripsi ke layanan hosting Anda.

  5. Daftar dengan Capgo:

    Jendela 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. Buat aplikasi Anda:

    Jendela terminal
    npm run build
  2. Unggah langsung ke S3:

    Jendela 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. Buat dan zip:

    Jendela terminal
    npm run build
    npx @capgo/cli@latest bundle zip com.example.app --path ./dist --key-v2
  2. Enkripsi bundle:

    Jendela terminal
    npx @capgo/cli@latest bundle encrypt ./com.example.app.zip CHECKSUM
  3. Unggah ke S3 dengan enkripsi:

    Jendela 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

Ketika menggunakan penyimpanan kustom, pertimbangkan praktik keamanan ini:

  • Pastikan URL penyimpanan Anda dapat diakses oleh pengguna aplikasi Anda tetapi tidak dapat ditemukan secara publik
  • Gunakan URL yang ditandatangani atau otentikasi berbasis token ketika memungkinkan
  • Implementasikan header CORS yang tepat untuk aplikasi berbasis web
  • Selalu enkripsi bundle sensitif menggunakan alat enkripsi Capgo
  • Simpan kunci enkripsi secara aman dan rotasinya secara teratur
  • Gunakan HTTPS untuk semua URL bundle (diperlukan untuk aplikasi mobile dan Electron)
  • Monitor log akses untuk mendeteksi pola download tidak biasa
  • Atur notifikasi untuk download bundle gagal
  • Audit secara teratur izin penyimpanan

Tidak dapat mengunduh bundle:

  • Pastikan URL dapat diakses secara publik dan menggunakan HTTPS (diperlukan untuk aplikasi mobile dan Electron)
  • Periksa header CORS untuk aplikasi web
  • Pastikan format bundle benar

Kesalahan enkripsi:

  • Pastikan ivSessionKey sama dengan bundle yang dienkripsi
  • Periksa apakah bundle dienkripsi dengan kunci yang benar
  • Pastikan menggunakan enkripsi v2 untuk bundle baru

Kegagalan unggah ke S3:

  • Pastikan kredential dan izin S3 Anda
  • Periksa kebijakan bucket dan konfigurasi CORS
  • Pastikan wilayah yang ditentukan benar

Periksa status bundel:

Jendela Terminal
npx @capgo/cli@latest app debug

Verifikasi integritas bundel:

Jendela Terminal
npx @capgo/cli@latest bundle list
  • Pelajari tentang Saluran untuk mengelola berbagai lingkungan pengiriman
  • Tamu Perilaku Update untuk mengcustomisasi bagaimana pembaruan diterapkan
  • Tetapkan Integrasi CI/CD untuk mengotomatisasi alur kerja penyimpanan kustom Anda

__CAPGO_KEEP_0__

Jika Anda menggunakan

__CAPGO_KEEP_1__ Penyimpanan Kustom untuk merencanakan keamanan dan keterbatasan, hubungkannya dengan Enkripsi untuk detail implementasi di Enkripsi, Keterbatasan untuk detail implementasi di Keterbatasan, Capgo Scanner Keamanan untuk alur kerja produk di Capgo Scanner Keamanan, Capgo Keamanan untuk alur kerja produk di Capgo Keamanan, dan Capgo Pusat Kepercayaan untuk alur kerja produk di Capgo Pusat Kepercayaan.