Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
SPEKE API v2 - Kustomisasi dan kendala untuk spesifikasi DASH-IF
Spesifikasi DASH Industry Forum CPIX 2.3
Profil CPIX
-
SPEKE mengikuti alur kerja Encryptor Consumer.
-
Untuk kunci konten terenkripsi, SPEKE menerapkan batasan berikut:
-
SPEKE tidak mendukung verifikasi tanda tangan digital (XMLDSIG) untuk muatan permintaan atau respons.
-
SPEKE membutuhkan 2048 sertifikat berbasis RSA.
-
-
SPEKE hanya memanfaatkan sebagian dari fungsionalitas CPIX:
-
SPEKE menghilangkan fungsionalitas.
UpdateHistoryItemListJika daftar hadir dalam tanggapan, SPEKE mengabaikannya. -
SPEKE menghilangkan fungsionalitas kunci akar/daun. Jika
ContentKey@dependsOnKeyatribut hadir dalam respons, SPEKE mengabaikannya. -
SPEKE menghilangkan
BitrateFilterelemen dan atribut.VideoFilter@wcgJika elemen atau atribut ini ada dalam muatan CPIX, SPEKE mengabaikannya.
-
-
Hanya elemen atau atribut yang dirujuk sebagai 'Didukung' pada halaman Komponen Muatan Standar atau halaman kontrak Enkripsi yang dapat digunakan dalam dokumen CPIX yang dipertukarkan dengan SPEKE v2.
-
Ketika disertakan dalam permintaan CPIX oleh enkripsi, semua elemen dan atribut harus membawa nilai yang valid dalam respons CPIX penyedia kunci. Jika tidak, enkripsi akan berhenti dan melempar kesalahan.
-
SPEKE mendukung rotasi kunci dengan
KeyPeriodFilterelemen. SPEKE hanya menggunakanContentKeyPeriod@indexuntuk melacak periode kunci. -
Untuk pensinyalan HLS, beberapa
DRMSystem.HLSSignalingDataelemen harus digunakan: satu dengan nilaiDRMSystem.HLSSignalingData@playlistatribut 'media', dan satu lagi dengan nilaiDRMSystem.HLSSignalingData@playlistatribut 'master'. -
Saat meminta kunci, enkripsi mungkin menggunakan
@explicitIVatribut opsional pada elemen.ContentKeyPenyedia kunci dapat merespons dengan menggunakan IV@explicitIV, bahkan jika atribut tidak termasuk dalam permintaan. -
Enkripsi membuat pengenal kunci (
KID), yang tetap sama untuk setiap ID konten dan periode kunci tertentu. Penyedia kunci memasukkanKIDdalam tanggapannya terhadap dokumen permintaan. -
Enkripsi harus menyertakan nilai untuk atribut.
CPIX@contentIdSaat menerima nilai kosong untuk atribut ini, penyedia kunci akan mengembalikan kesalahan dengan deskripsi 'Missing CPIX @contentId '.CPIX@contentIdnilai tidak dapat diganti oleh penyedia kunci.CPIX@idnilai, jika tidak null, akan diabaikan oleh penyedia kunci. -
Enkripsi harus menyertakan nilai untuk atribut.
CPIX@versionSaat menerima nilai kosong untuk atribut ini, penyedia kunci akan mengembalikan kesalahan dengan deskripsi 'Missing CPIX @version '. Saat menerima permintaan dengan versi yang tidak didukung, deskripsi kesalahan yang dikembalikan oleh penyedia kunci adalah 'CPIX @version Tidak Didukung '.CPIX@versionnilai tidak dapat diganti oleh penyedia kunci. -
Enkripsi harus menyertakan nilai untuk
ContentKey@commonEncryptionSchemeatribut untuk setiap kunci yang diminta. Saat menerima nilai kosong untuk atribut ini, penyedia kunci akan mengembalikan kesalahan dengan deskripsi 'Missing ContentKey @ commonEncryptionScheme foridKID'.Dokumen CPIX unik tidak dapat mencampur beberapa nilai untuk atribut yang berbeda
ContentKey@commonEncryptionScheme. Saat menerima kombinasi seperti itu, penyedia kunci akan mengembalikan kesalahan dengan deskripsi 'Non compliant ContentKey @ commonEncryptionScheme combination'.Tidak semua
ContentKey@commonEncryptionSchemenilai kompatibel dengan semua teknologi DRM. Saat menerima kombinasi seperti itu, penyedia kunci akan mengembalikan kesalahan dengan deskripsi 'ContentKey@ commonEncryptionScheme tidak kompatibel dengan DRMSystemid'.ContentKey@commonEncryptionSchemenilai tidak dapat diganti oleh penyedia kunci. -
Saat menerima nilai yang berbeda untuk
DRMSystem@PSSHdan<pssh>elemenDRMSystem.ContentProtectionDatainnerXML di badan respons CPIX, enkripsi akan berhenti dan menimbulkan kesalahan.
API untuk CPIX
-
Penyedia kunci harus menyertakan nilai untuk header respons
X-Speke-User-AgentHTTP. -
Sebuah enkripsi Speke-compliant bertindak sebagai klien dan mengirimkan operasi POST ke endpoint penyedia kunci.
-
Enkripsi harus menyertakan nilai untuk header permintaan
X-Speke-VersionHTTP, dengan versi SPEKE yang digunakan dengan permintaan, dirumuskan sebagai. MajorVersion MinorVersion, seperti '2.0' untuk SPEKE v2.0. Jika penyedia kunci tidak mendukung versi SPEKE yang digunakan oleh enkripsi untuk permintaan saat ini, penyedia kunci akan mengembalikan kesalahan dengan deskripsi 'Versi SPEKE Tidak Didukung' dan tidak mencoba memproses dokumen CPIX dengan upaya terbaik.Nilai
X-Speke-Versionheader yang ditentukan oleh enkripsi tidak dapat dimodifikasi oleh penyedia kunci dalam menanggapi permintaan. -
Saat menerima kesalahan di badan respons, enkripsi akan melempar kesalahan dan tidak mencoba lagi permintaan dengan versi SPEKE v1.0.
Jika penyedia kunci tidak mengembalikan kesalahan tetapi gagal mengembalikan dokumen CPIX yang menyertakan informasi wajib, enkripsi harus berhenti dan menimbulkan kesalahan.
Tabel berikut merangkum pesan standar yang harus dikembalikan oleh penyedia kunci di badan pesan. Kode respons HTTP dalam kasus kesalahan harus berupa 4XX atau 5XX, tidak pernah 200. Kode kesalahan 422 dapat digunakan untuk semua kesalahan yang terkait dengan SPEKE/CPIX.
| Kasus kesalahan | Pesan kesalahan |
|---|---|
|
CPIX @contentId tidak ditentukan |
CPIX @contentId tidak ada |
|
CPIX @version tidak ditentukan |
CPIX @version tidak ada |
|
CPIX @version tidak didukung |
CPIX @version tidak didukung |
|
ContentKey@ commonEncryptionScheme tidak didefinisikan |
Hilang ContentKey @ commonEncryptionScheme untuk KID |
|
Beberapa commonEncryptionScheme nilai ContentKey @ yang digunakan dalam satu dokumen CPIX |
Kombinasi ContentKey @ commonEncryptionScheme yang tidak sesuai |
|
ContentKey@ commonEncryptionScheme tidak kompatibel dengan teknologi DRM |
ContentKey@ commonEncryptionScheme tidak kompatibel dengan DRMSystem |
|
X-Speke-Version nilai header bukan versi SPEKE yang didukung |
Versi SPEKE yang tidak didukung |
|
Kontrak enkripsi cacat |
Kontrak enkripsi cacat |
|
Kontrak enkripsi bertentangan dengan batasan tingkat keamanan DRM |
Kontrak enkripsi CPIX yang diminta tidak didukung |
|
Kontrak enkripsi tidak termasuk AudioFilter elemen VideoFilter atau |
Kontrak enkripsi CPIX tidak ada |