1 /*
2  * Copyright (C) 2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef MEDIA_SOURCE_NAPI_H
17 #define MEDIA_SOURCE_NAPI_H
18 
19 #include "napi/native_api.h"
20 #include "napi/native_node_api.h"
21 #include "common_napi.h"
22 
23 namespace OHOS {
24 namespace Media {
25 
26 class MediaSourceNapi {
27 public:
28     __attribute__((visibility("default"))) static napi_value Init(napi_env env, napi_value exports);
29     static std::shared_ptr<AVMediaSourceTmp> GetMediaSource(napi_env env, napi_value jsMediaSource);
30 private:
31     static napi_value Constructor(napi_env env, napi_callback_info info);
32     static void Destructor(napi_env env, void *nativeObject, void *finalize);
33     /**
34      * function createMediaSourceWithUrl(url: string, header?: string): MediaSource
35      */
36     static napi_value JsCreateMediaSourceWithUrl(napi_env env, napi_callback_info info);
37     /**
38      * function setMimeType(mimeType: AVMimeType): MediaSource
39      */
40     static napi_value JsSetMimeType(napi_env env, napi_callback_info info);
41 
42     MediaSourceNapi() = default;
43     virtual ~MediaSourceNapi() = default;
44 
45     static thread_local napi_ref constructor_;
46     napi_env env_ = nullptr;
47     std::shared_ptr<AVMediaSourceTmp> mediaSource_ {nullptr};
48 };
49 
50 } // Media
51 } // OHOS
52 
53 #endif // MEDIA_SOURCE_NAPI_H