1 #ifndef __DALI_TIZEN_PLATFORM_NETWORK_FILE_DOWNLOAD_H__
2 #define __DALI_TIZEN_PLATFORM_NETWORK_FILE_DOWNLOAD_H__
5 * Copyright (c) 2018 Samsung Electronics Co., Ltd.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
22 #include <dali/public-api/common/dali-vector.h>
24 #include <mutex> //c++11
25 #include <stdint.h> // uint8
30 namespace TizenPlatform
37 * Set up the cURL environment - this will ensure curl_global_init is called on startup
38 * and curl_global_cleanup is called on shutdown.
39 * Having this environment enables curl to be used in a single or multi-threaded
46 * Constructor calls curl_global_init()
51 * Destructor calls curl_global_cleanup()
55 // Moveable but not copyable
57 CurlEnvironment( const CurlEnvironment& ) = delete;
58 CurlEnvironment& operator=( const CurlEnvironment& ) = delete;
59 CurlEnvironment( CurlEnvironment&& ) = default;
60 CurlEnvironment& operator=( CurlEnvironment&& ) = default;
63 * Locking function for libcurl with openssl
65 static void OnOpenSSLLocking( int mode, int n, const char* file, int line );
68 * Gets thread id for libcurl with openssl
70 static unsigned long GetThreadId();
74 void SetLockingFunction();
76 void UnsetLockingFunction();
78 static std::mutex* mMutexs;
83 * Download a requested file into a memory buffer.
85 * @note Threading notes: This function can be called from multiple threads, however
86 * we must explicitly call curl_global_init() from a single thread before using curl
87 * as the global function calls are not thread safe.
89 * @param[in] url The requested file url
90 * @param[out] dataBuffer A memory buffer object to be written with downloaded file data.
91 * @param[out] dataSize The size of the memory buffer.
92 * @param[in] maximumAllowedSize The maxmimum allowed file size in bytes to download. E.g. for an Image file this may be 50 MB
93 * @return true on success, false on failure
96 bool DownloadRemoteFileIntoMemory( const std::string& url,
97 Dali::Vector<uint8_t>& dataBuffer,
99 size_t maximumAllowedSizeBytes );
101 } // namespace Network
103 } // namespace TizenPlatform
107 #endif // __DALI_TIZEN_PLATFORM_RESOURCE_THREAD_IMAGE_H__