1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 * Use of this source code is governed by a BSD-style license that can be
3 * found in the LICENSE file.
6 /* From private/ppb_flash_drm.idl modified Sat Jun 8 16:45:26 2013. */
8 #ifndef PPAPI_C_PRIVATE_PPB_FLASH_DRM_H_
9 #define PPAPI_C_PRIVATE_PPB_FLASH_DRM_H_
11 #include "ppapi/c/pp_bool.h"
12 #include "ppapi/c/pp_completion_callback.h"
13 #include "ppapi/c/pp_instance.h"
14 #include "ppapi/c/pp_macros.h"
15 #include "ppapi/c/pp_resource.h"
16 #include "ppapi/c/pp_stdint.h"
17 #include "ppapi/c/pp_var.h"
19 #define PPB_FLASH_DRM_INTERFACE_1_0 "PPB_Flash_DRM;1.0"
20 #define PPB_FLASH_DRM_INTERFACE PPB_FLASH_DRM_INTERFACE_1_0
24 * This file contains the <code>PPB_Flash_DRM</code> interface.
29 * @addtogroup Interfaces
33 * A resource for performing Flash DRM-related operations.
35 struct PPB_Flash_DRM_1_0
{
37 * Creates a PPB_Flash_DRM resource for performing DRM-related operations in
40 PP_Resource (*Create
)(PP_Instance instance
);
42 * Asynchronously computes the device ID. When available, it will place the
43 * string in |*id| and will call the completion callback. On failure the
44 * given var will be PP_VARTYPE_UNDEFINED.
46 int32_t (*GetDeviceID
)(PP_Resource drm
,
48 struct PP_CompletionCallback callback
);
50 * Windows only. Synchronously outputs the HMONITOR corresponding to the
51 * monitor on which the plugin instance is displayed in |hmonitor|. PP_TRUE is
52 * returned on success.
54 PP_Bool (*GetHmonitor
)(PP_Resource drm
, int64_t* hmonitor
);
56 * Asynchronously returns a PPB_FileRef resource in |file_ref| which points to
57 * the Voucher file for performing DRM verification. |callback| will be called
60 int32_t (*GetVoucherFile
)(PP_Resource drm
,
61 PP_Resource
* file_ref
,
62 struct PP_CompletionCallback callback
);
65 typedef struct PPB_Flash_DRM_1_0 PPB_Flash_DRM
;
70 #endif /* PPAPI_C_PRIVATE_PPB_FLASH_DRM_H_ */