2019-12-25 14:25:26 +08:00
|
|
|
|
/*
|
2020-04-04 20:30:09 +08:00
|
|
|
|
* Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
|
2019-12-25 14:25:26 +08:00
|
|
|
|
*
|
2021-01-17 18:31:50 +08:00
|
|
|
|
* This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
|
2019-12-25 14:25:26 +08:00
|
|
|
|
*
|
2020-04-04 20:30:09 +08:00
|
|
|
|
* Use of this source code is governed by MIT license that can be found in the
|
|
|
|
|
* LICENSE file in the root of the source tree. All contributing project authors
|
|
|
|
|
* may be found in the AUTHORS file in the root of the source tree.
|
2019-12-25 14:25:26 +08:00
|
|
|
|
*/
|
2020-04-04 20:30:09 +08:00
|
|
|
|
|
2019-12-27 10:10:31 +08:00
|
|
|
|
#include "mk_httpclient.h"
|
2019-12-25 14:25:26 +08:00
|
|
|
|
|
|
|
|
|
#include "Util/logger.h"
|
|
|
|
|
#include "Http/HttpDownloader.h"
|
|
|
|
|
#include "Http/HttpRequester.h"
|
|
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
using namespace toolkit;
|
|
|
|
|
using namespace mediakit;
|
|
|
|
|
|
|
|
|
|
API_EXPORT mk_http_downloader API_CALL mk_http_downloader_create() {
|
|
|
|
|
HttpDownloader::Ptr *obj(new HttpDownloader::Ptr(new HttpDownloader()));
|
|
|
|
|
return (mk_http_downloader) obj;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_downloader_release(mk_http_downloader ctx) {
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpDownloader::Ptr *obj = (HttpDownloader::Ptr *) ctx;
|
|
|
|
|
delete obj;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_downloader_start(mk_http_downloader ctx, const char *url, const char *file, on_mk_download_complete cb, void *user_data) {
|
2023-02-11 15:14:18 +08:00
|
|
|
|
mk_http_downloader_start2(ctx, url, file, cb, user_data, nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_downloader_start2(mk_http_downloader ctx, const char *url, const char *file, on_mk_download_complete cb, void *user_data, on_user_data_free user_data_free) {
|
2019-12-25 14:25:26 +08:00
|
|
|
|
assert(ctx && url && file);
|
|
|
|
|
HttpDownloader::Ptr *obj = (HttpDownloader::Ptr *) ctx;
|
2023-02-11 15:14:18 +08:00
|
|
|
|
std::shared_ptr<void> ptr(user_data, user_data_free ? user_data_free : [](void *) {});
|
|
|
|
|
(*obj)->setOnResult([cb, ptr](const SockException &ex, const string &filePath) {
|
2019-12-25 14:25:26 +08:00
|
|
|
|
if (cb) {
|
2023-02-11 15:14:18 +08:00
|
|
|
|
cb(ptr.get(), ex.getErrCode(), ex.what(), filePath.data());
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
(*obj)->startDownload(url, file, false);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////HttpRequester/////////////////////////////////////////////
|
|
|
|
|
API_EXPORT mk_http_requester API_CALL mk_http_requester_create(){
|
|
|
|
|
HttpRequester::Ptr *ret = new HttpRequester::Ptr(new HttpRequester);
|
2023-02-26 21:45:14 +08:00
|
|
|
|
return (mk_http_requester)ret;
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_clear(mk_http_requester ctx){
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
(*obj)->clear();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_release(mk_http_requester ctx){
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
delete obj;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_set_method(mk_http_requester ctx,const char *method){
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
(*obj)->setMethod(method);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template <typename C = StrCaseMap>
|
|
|
|
|
static C get_http_header( const char *response_header[]){
|
|
|
|
|
C header;
|
|
|
|
|
for (int i = 0; response_header[i] != NULL;) {
|
|
|
|
|
auto key = response_header[i];
|
|
|
|
|
auto value = response_header[i + 1];
|
|
|
|
|
if (key && value) {
|
|
|
|
|
i += 2;
|
2019-12-28 13:39:25 +08:00
|
|
|
|
header.emplace(key,value);
|
2019-12-25 14:25:26 +08:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
2020-09-21 14:32:56 +08:00
|
|
|
|
return header;
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_set_body(mk_http_requester ctx, mk_http_body body){
|
|
|
|
|
assert(ctx && body);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
HttpBody::Ptr *body_obj = (HttpBody::Ptr *)body;
|
|
|
|
|
(*obj)->setBody(*body_obj);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_set_header(mk_http_requester ctx, const char *header[]){
|
|
|
|
|
assert(ctx && header);
|
|
|
|
|
auto header_obj = get_http_header(header);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
(*obj)->setHeader(header_obj);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_add_header(mk_http_requester ctx,const char *key,const char *value,int force){
|
|
|
|
|
assert(ctx && key && value);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
(*obj)->addHeader(key,value,force);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT const char* API_CALL mk_http_requester_get_response_status(mk_http_requester ctx){
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
2023-06-10 11:04:52 +08:00
|
|
|
|
return (*obj)->response().status().c_str();
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT const char* API_CALL mk_http_requester_get_response_header(mk_http_requester ctx,const char *key){
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
return (*obj)->response()[key].c_str();
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-17 18:31:50 +08:00
|
|
|
|
API_EXPORT const char* API_CALL mk_http_requester_get_response_body(mk_http_requester ctx, size_t *length){
|
2019-12-25 14:25:26 +08:00
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
if(length){
|
2023-06-10 11:04:52 +08:00
|
|
|
|
*length = (*obj)->response().content().size();
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
2023-06-10 11:04:52 +08:00
|
|
|
|
return (*obj)->response().content().c_str();
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT mk_parser API_CALL mk_http_requester_get_response(mk_http_requester ctx){
|
|
|
|
|
assert(ctx);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
|
|
|
|
return (mk_parser)&((*obj)->response());
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-11 15:14:18 +08:00
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_set_cb(mk_http_requester ctx,on_mk_http_requester_complete cb, void *user_data) {
|
|
|
|
|
mk_http_requester_set_cb2(ctx, cb, user_data, nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_set_cb2(mk_http_requester ctx,on_mk_http_requester_complete cb, void *user_data, on_user_data_free user_data_free) {
|
2019-12-25 14:25:26 +08:00
|
|
|
|
assert(ctx && cb);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
2023-02-11 15:14:18 +08:00
|
|
|
|
std::shared_ptr<void> ptr(user_data, user_data_free ? user_data_free : [](void *) {});
|
|
|
|
|
(*obj)->setOnResult([cb, ptr](const SockException &ex, const Parser &res) {
|
|
|
|
|
cb(ptr.get(), ex.getErrCode(), ex.what());
|
2019-12-25 14:25:26 +08:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
API_EXPORT void API_CALL mk_http_requester_start(mk_http_requester ctx,const char *url, float timeout_second){
|
|
|
|
|
assert(ctx && url && url[0] && timeout_second > 0);
|
|
|
|
|
HttpRequester::Ptr *obj = (HttpRequester::Ptr *)ctx;
|
2022-01-19 22:50:44 +08:00
|
|
|
|
(*obj)->setCompleteTimeout(timeout_second * 1000);
|
|
|
|
|
(*obj)->sendRequest(url);
|
2019-12-25 14:25:26 +08:00
|
|
|
|
}
|
|
|
|
|
|