OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef MEDIA_BASE_PROVISION_FETCHER_H | 5 #ifndef MEDIA_BASE_PROVISION_FETCHER_H |
6 #define MEDIA_BASE_PROVISION_FETCHER_H | 6 #define MEDIA_BASE_PROVISION_FETCHER_H |
7 | 7 |
| 8 #include <memory> |
8 #include <string> | 9 #include <string> |
9 | 10 |
10 #include "base/callback.h" | 11 #include "base/callback.h" |
11 #include "base/memory/scoped_ptr.h" | |
12 #include "media/base/media_export.h" | 12 #include "media/base/media_export.h" |
13 | 13 |
14 namespace media { | 14 namespace media { |
15 | 15 |
16 // The interface to retrieve provision information for MediaDrmBridge. | 16 // The interface to retrieve provision information for MediaDrmBridge. |
17 class MEDIA_EXPORT ProvisionFetcher { | 17 class MEDIA_EXPORT ProvisionFetcher { |
18 public: | 18 public: |
19 // After provision information is retrieved this callback will be called | 19 // After provision information is retrieved this callback will be called |
20 // with the status flag (success/failure) and the provision response in | 20 // with the status flag (success/failure) and the provision response in |
21 // case of success. | 21 // case of success. |
22 using ResponseCB = | 22 using ResponseCB = |
23 base::Callback<void(bool success, const std::string& response)>; | 23 base::Callback<void(bool success, const std::string& response)>; |
24 | 24 |
25 virtual ~ProvisionFetcher() {} | 25 virtual ~ProvisionFetcher() {} |
26 | 26 |
27 // Requests the provision information with |default_url| and |request_data| | 27 // Requests the provision information with |default_url| and |request_data| |
28 // and calls |response_cb| callback with the response. The input parameters | 28 // and calls |response_cb| callback with the response. The input parameters |
29 // |default_url| and |request_data| corresponds to Java class | 29 // |default_url| and |request_data| corresponds to Java class |
30 // MediaDrm.ProvisionRequest. | 30 // MediaDrm.ProvisionRequest. |
31 // The implementation must call |response_cb| asynchronously on the same | 31 // The implementation must call |response_cb| asynchronously on the same |
32 // thread that this method is called. | 32 // thread that this method is called. |
33 virtual void Retrieve(const std::string& default_url, | 33 virtual void Retrieve(const std::string& default_url, |
34 const std::string& request_data, | 34 const std::string& request_data, |
35 const ResponseCB& response_cb) = 0; | 35 const ResponseCB& response_cb) = 0; |
36 }; | 36 }; |
37 | 37 |
38 using CreateFetcherCB = base::Callback<scoped_ptr<ProvisionFetcher>()>; | 38 using CreateFetcherCB = base::Callback<std::unique_ptr<ProvisionFetcher>()>; |
39 | 39 |
40 } // namespace media | 40 } // namespace media |
41 | 41 |
42 #endif // MEDIA_BASE_PROVISION_FETCHER_H | 42 #endif // MEDIA_BASE_PROVISION_FETCHER_H |
OLD | NEW |