blob: 3d4b0fc7a052e9b0fb8ba07543536d75728feb01 [file] [log] [blame]
Jeff Tinkercc82dc62013-02-08 10:18:35 -08001/*
2 * Copyright (C) 2013 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef DRM_H_
18
19#define DRM_H_
20
21#include "SharedLibrary.h"
22
23#include <media/IDrm.h>
Jeff Tinker0cb126a2013-04-02 13:08:05 -070024#include <media/IDrmClient.h>
Jeff Tinkercc82dc62013-02-08 10:18:35 -080025#include <utils/threads.h>
26
27namespace android {
28
29struct DrmFactory;
30struct DrmPlugin;
31
Jeff Tinker3d3f67f2013-07-03 15:38:58 -070032struct Drm : public BnDrm,
33 public IBinder::DeathRecipient,
34 public DrmPluginListener {
Jeff Tinkercc82dc62013-02-08 10:18:35 -080035 Drm();
36 virtual ~Drm();
37
38 virtual status_t initCheck() const;
39
Jeff Tinker9cf69e02013-08-21 11:59:23 -070040 virtual bool isCryptoSchemeSupported(const uint8_t uuid[16], const String8 &mimeType);
Jeff Tinkercc82dc62013-02-08 10:18:35 -080041
42 virtual status_t createPlugin(const uint8_t uuid[16]);
43
44 virtual status_t destroyPlugin();
45
46 virtual status_t openSession(Vector<uint8_t> &sessionId);
47
48 virtual status_t closeSession(Vector<uint8_t> const &sessionId);
49
50 virtual status_t
Jeff Tinker8856c8b2013-03-30 16:19:44 -070051 getKeyRequest(Vector<uint8_t> const &sessionId,
52 Vector<uint8_t> const &initData,
53 String8 const &mimeType, DrmPlugin::KeyType keyType,
54 KeyedVector<String8, String8> const &optionalParameters,
55 Vector<uint8_t> &request, String8 &defaultUrl);
Jeff Tinkercc82dc62013-02-08 10:18:35 -080056
Jeff Tinker8856c8b2013-03-30 16:19:44 -070057 virtual status_t provideKeyResponse(Vector<uint8_t> const &sessionId,
58 Vector<uint8_t> const &response,
59 Vector<uint8_t> &keySetId);
Jeff Tinkercc82dc62013-02-08 10:18:35 -080060
Jeff Tinker8856c8b2013-03-30 16:19:44 -070061 virtual status_t removeKeys(Vector<uint8_t> const &keySetId);
Jeff Tinkercc82dc62013-02-08 10:18:35 -080062
Jeff Tinker8856c8b2013-03-30 16:19:44 -070063 virtual status_t restoreKeys(Vector<uint8_t> const &sessionId,
64 Vector<uint8_t> const &keySetId);
65
66 virtual status_t queryKeyStatus(Vector<uint8_t> const &sessionId,
67 KeyedVector<String8, String8> &infoMap) const;
Jeff Tinkercc82dc62013-02-08 10:18:35 -080068
Jeff Tinker68d9d712014-03-04 13:21:31 -080069 virtual status_t getProvisionRequest(String8 const &certType,
70 String8 const &certAuthority,
71 Vector<uint8_t> &request,
Jeff Tinkercc82dc62013-02-08 10:18:35 -080072 String8 &defaulUrl);
73
Jeff Tinker68d9d712014-03-04 13:21:31 -080074 virtual status_t provideProvisionResponse(Vector<uint8_t> const &response,
75 Vector<uint8_t> &certificate,
76 Vector<uint8_t> &wrappedKey);
Jeff Tinkercc82dc62013-02-08 10:18:35 -080077
78 virtual status_t getSecureStops(List<Vector<uint8_t> > &secureStops);
79
80 virtual status_t releaseSecureStops(Vector<uint8_t> const &ssRelease);
81
82 virtual status_t getPropertyString(String8 const &name, String8 &value ) const;
83 virtual status_t getPropertyByteArray(String8 const &name,
84 Vector<uint8_t> &value ) const;
85 virtual status_t setPropertyString(String8 const &name, String8 const &value ) const;
86 virtual status_t setPropertyByteArray(String8 const &name,
87 Vector<uint8_t> const &value ) const;
88
Jeff Tinker8856c8b2013-03-30 16:19:44 -070089 virtual status_t setCipherAlgorithm(Vector<uint8_t> const &sessionId,
90 String8 const &algorithm);
91
92 virtual status_t setMacAlgorithm(Vector<uint8_t> const &sessionId,
93 String8 const &algorithm);
94
95 virtual status_t encrypt(Vector<uint8_t> const &sessionId,
96 Vector<uint8_t> const &keyId,
97 Vector<uint8_t> const &input,
98 Vector<uint8_t> const &iv,
99 Vector<uint8_t> &output);
100
101 virtual status_t decrypt(Vector<uint8_t> const &sessionId,
102 Vector<uint8_t> const &keyId,
103 Vector<uint8_t> const &input,
104 Vector<uint8_t> const &iv,
105 Vector<uint8_t> &output);
106
107 virtual status_t sign(Vector<uint8_t> const &sessionId,
108 Vector<uint8_t> const &keyId,
109 Vector<uint8_t> const &message,
110 Vector<uint8_t> &signature);
111
112 virtual status_t verify(Vector<uint8_t> const &sessionId,
113 Vector<uint8_t> const &keyId,
114 Vector<uint8_t> const &message,
115 Vector<uint8_t> const &signature,
116 bool &match);
117
Jeff Tinker68d9d712014-03-04 13:21:31 -0800118 virtual status_t signRSA(Vector<uint8_t> const &sessionId,
119 String8 const &algorithm,
120 Vector<uint8_t> const &message,
121 Vector<uint8_t> const &wrappedKey,
122 Vector<uint8_t> &signature);
123
Jeff Tinker0cb126a2013-04-02 13:08:05 -0700124 virtual status_t setListener(const sp<IDrmClient>& listener);
125
126 virtual void sendEvent(DrmPlugin::EventType eventType, int extra,
127 Vector<uint8_t> const *sessionId,
128 Vector<uint8_t> const *data);
129
Jeff Tinker3d3f67f2013-07-03 15:38:58 -0700130 virtual void binderDied(const wp<IBinder> &the_late_who);
131
Jeff Tinkercc82dc62013-02-08 10:18:35 -0800132private:
133 mutable Mutex mLock;
134
135 status_t mInitCheck;
Jeff Tinker0cb126a2013-04-02 13:08:05 -0700136
137 sp<IDrmClient> mListener;
138 mutable Mutex mEventLock;
139 mutable Mutex mNotifyLock;
140
Jeff Tinkercc82dc62013-02-08 10:18:35 -0800141 sp<SharedLibrary> mLibrary;
142 DrmFactory *mFactory;
143 DrmPlugin *mPlugin;
144
145 static KeyedVector<Vector<uint8_t>, String8> mUUIDToLibraryPathMap;
146 static KeyedVector<String8, wp<SharedLibrary> > mLibraryPathToOpenLibraryMap;
147 static Mutex mMapLock;
148
149 void findFactoryForScheme(const uint8_t uuid[16]);
150 bool loadLibraryForScheme(const String8 &path, const uint8_t uuid[16]);
151 void closeFactory();
152
153
154 DISALLOW_EVIL_CONSTRUCTORS(Drm);
155};
156
157} // namespace android
158
159#endif // CRYPTO_H_