1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
|
/*
* Copyright (C) 2010 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __DRM_FRAMEWORK_COMMON_H__
#define __DRM_FRAMEWORK_COMMON_H__
#include <utils/Vector.h>
#include <utils/KeyedVector.h>
#include <utils/RefBase.h>
#include <utils/String8.h>
#include <utils/Errors.h>
#define INVALID_VALUE -1
namespace android {
/**
* Error code for DRM Frameowrk
*/
enum {
// The following constant values should be in sync with
// media/stagefright/MediaErrors.h
ERROR_BASE = -2000,
DRM_ERROR_UNKNOWN = ERROR_BASE,
DRM_ERROR_NO_LICENSE = ERROR_BASE - 1,
DRM_ERROR_LICENSE_EXPIRED = ERROR_BASE - 2,
DRM_ERROR_SESSION_NOT_OPENED = ERROR_BASE - 3,
DRM_ERROR_DECRYPT_UNIT_NOT_INITIALIZED = ERROR_BASE - 4,
DRM_ERROR_DECRYPT = ERROR_BASE - 5,
DRM_ERROR_CANNOT_HANDLE = ERROR_BASE - 6,
DRM_ERROR_TAMPER_DETECTED = ERROR_BASE - 7,
DRM_NO_ERROR = NO_ERROR
};
/**
* copy control settings used in DecryptHandle::copyControlVector
*/
enum DrmCopyControl {
DRM_COPY_CONTROL_BASE = 1000,
// the key used to set the value for HDCP
// if the associated value is 1, then HDCP is required
// otherwise, HDCP is not required
DRM_COPY_CONTROL_HDCP = DRM_COPY_CONTROL_BASE
};
/**
* Defines DRM Buffer
*/
class DrmBuffer {
public:
char* data;
int length;
DrmBuffer() :
data(NULL),
length(0) {
}
DrmBuffer(char* dataBytes, int dataLength) :
data(dataBytes),
length(dataLength) {
}
};
/**
* Defines detailed description of the action
*/
class ActionDescription {
public:
ActionDescription(int _outputType, int _configuration) :
outputType(_outputType),
configuration(_configuration) {
}
public:
int outputType; /* BLUETOOTH , HDMI*/
int configuration; /* RESOLUTION_720_480 , RECORDABLE etc.*/
};
/**
* Defines constants related to DRM types
*/
class DrmObjectType {
private:
DrmObjectType();
public:
/**
* Field specifies the unknown type
*/
static const int UNKNOWN = 0x00;
/**
* Field specifies the protected content type
*/
static const int CONTENT = 0x01;
/**
* Field specifies the rights information
*/
static const int RIGHTS_OBJECT = 0x02;
/**
* Field specifies the trigger information
*/
static const int TRIGGER_OBJECT = 0x03;
};
/**
* Defines constants related to play back
*/
class Playback {
private:
Playback();
public:
/**
* Constant field signifies playback start
*/
static const int START = 0x00;
/**
* Constant field signifies playback stop
*/
static const int STOP = 0x01;
/**
* Constant field signifies playback paused
*/
static const int PAUSE = 0x02;
/**
* Constant field signifies playback resumed
*/
static const int RESUME = 0x03;
};
/**
* Defines actions that can be performed on protected content
*/
class Action {
private:
Action();
public:
/**
* Constant field signifies that the default action
*/
static const int DEFAULT = 0x00;
/**
* Constant field signifies that the content can be played
*/
static const int PLAY = 0x01;
/**
* Constant field signifies that the content can be set as ring tone
*/
static const int RINGTONE = 0x02;
/**
* Constant field signifies that the content can be transfered
*/
static const int TRANSFER = 0x03;
/**
* Constant field signifies that the content can be set as output
*/
static const int OUTPUT = 0x04;
/**
* Constant field signifies that preview is allowed
*/
static const int PREVIEW = 0x05;
/**
* Constant field signifies that the content can be executed
*/
static const int EXECUTE = 0x06;
/**
* Constant field signifies that the content can displayed
*/
static const int DISPLAY = 0x07;
};
/**
* Defines constants related to status of the rights
*/
class RightsStatus {
private:
RightsStatus();
public:
/**
* Constant field signifies that the rights are valid
*/
static const int RIGHTS_VALID = 0x00;
/**
* Constant field signifies that the rights are invalid
*/
static const int RIGHTS_INVALID = 0x01;
/**
* Constant field signifies that the rights are expired for the content
*/
static const int RIGHTS_EXPIRED = 0x02;
/**
* Constant field signifies that the rights are not acquired for the content
*/
static const int RIGHTS_NOT_ACQUIRED = 0x03;
};
/**
* Defines API set for decryption
*/
class DecryptApiType {
private:
DecryptApiType();
public:
/**
* Decrypt API set for non encrypted content
*/
static const int NON_ENCRYPTED = 0x00;
/**
* Decrypt API set for ES based DRM
*/
static const int ELEMENTARY_STREAM_BASED = 0x01;
/**
* POSIX based Decrypt API set for container based DRM
*/
static const int CONTAINER_BASED = 0x02;
/**
* Decrypt API for Widevine streams
*/
static const int WV_BASED = 0x3;
};
/**
* Defines decryption information
*/
class DecryptInfo {
public:
/**
* size of memory to be allocated to get the decrypted content.
*/
int decryptBufferLength;
/**
* reserved for future purpose
*/
};
/**
* Defines decryption handle
*/
class DecryptHandle : public RefBase {
public:
/**
* Decryption session Handle
*/
int decryptId;
/**
* Mimetype of the content to be used to select the media extractor
* For e.g., "video/mpeg" or "audio/mp3"
*/
String8 mimeType;
/**
* Defines which decryption pattern should be used to decrypt the given content
* DrmFramework provides two different set of decryption APIs.
* 1. Decrypt APIs for elementary stream based DRM
* (file format is not encrypted but ES is encrypted)
* e.g., Marlin DRM (MP4 file format), WM-DRM (asf file format)
*
* DecryptApiType::ELEMENTARY_STREAM_BASED
* Decryption API set for ES based DRM
* initializeDecryptUnit(), decrypt(), and finalizeDecryptUnit()
* 2. Decrypt APIs for container based DRM (file format itself is encrypted)
* e.g., OMA DRM (dcf file format)
*
* DecryptApiType::CONTAINER_BASED
* POSIX based Decryption API set for container based DRM
* pread()
*/
int decryptApiType;
/**
* Defines the status of the rights like
* RIGHTS_VALID, RIGHTS_INVALID, RIGHTS_EXPIRED or RIGHTS_NOT_ACQUIRED
*/
int status;
/**
* Information required to decrypt content
* e.g. size of memory to be allocated to get the decrypted content.
*/
DecryptInfo* decryptInfo;
/**
* Defines a vector for the copy control settings sent from the DRM plugin
* to the player
*/
KeyedVector<DrmCopyControl, int> copyControlVector;
/**
* Defines a vector for any extra data the DRM plugin wants to send
* to the native code
*/
KeyedVector<String8, String8> extendedData;
public:
DecryptHandle():
decryptId(INVALID_VALUE),
mimeType(""),
decryptApiType(INVALID_VALUE),
status(INVALID_VALUE),
decryptInfo(NULL) {
}
~DecryptHandle() {
delete decryptInfo; decryptInfo = NULL;
}
bool operator<(const DecryptHandle& handle) const {
return (decryptId < handle.decryptId);
}
bool operator==(const DecryptHandle& handle) const {
return (decryptId == handle.decryptId);
}
};
};
#endif /* __DRM_FRAMEWORK_COMMON_H__ */
|