Skip to content

Commit

Permalink
Merge branch 'windows-server-2003:main' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
cooolgamer authored Mar 3, 2023
2 parents 656a92f + ba153c4 commit 0fa8674
Show file tree
Hide file tree
Showing 12 changed files with 116 additions and 63 deletions.
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ ROMFS := romfs
LIBRARY := library
GFXBUILD := $(ROMFS)/gfx
#---------------------------------------------------------------------------------
APP_VER := 82
APP_VER := 83
APP_TITLE := ThirdTube
APP_DESCRIPTION := A YouTube client for the 3DS
APP_AUTHOR := windows_server_2003
Expand Down
40 changes: 21 additions & 19 deletions decrypter/0_latest.txt
Original file line number Diff line number Diff line change
@@ -1,24 +1,26 @@
# 19369
# 19417
s 17
c 1
R
c 2
s 65
>
r -800848978
R
c 3
>R
s -962757806
e 330905968
r -1801395041
r -45203544
r 969944705
s -1266939812
s 1071587255
r 2070384319
t hwadna7 Aa0-_
s 61910453
R
t UDjUn 0aA-_
r -1700764381
R
r -1343083959
r 258676768
s 1600529817
s -321620231
r -65500503
r 301529828
s 1621916887
r -1772925964
t else 0aA-_
s 2024158092
s 316275604
R
s 2108090471
r 1565550281
e -1494726146
r 859083917
r -2140614363
r -307172264
R
3 changes: 2 additions & 1 deletion decrypter/archive/0/19369.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@ R
c 2
R
c 3
>R
>
R
s -962757806
R
R
Expand Down
26 changes: 26 additions & 0 deletions decrypter/archive/0/19417.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
# 19417
s 17
c 1
R
s 65
>
r -800848978
R
e 330905968
r -1801395041
r -45203544
r 969944705
s -1266939812
s 1071587255
r 2070384319
t hwadna7 Aa0-_
s 61910453
R
t UDjUn 0aA-_
r -1700764381
R
R
r 859083917
r -2140614363
r -307172264
R
48 changes: 22 additions & 26 deletions romfs/yt_decrypter.txt
Original file line number Diff line number Diff line change
@@ -1,30 +1,26 @@
# 19345
s 9
c 3
R
s 23
s 35
s 8
c 2
# 19417
s 17
c 1
R
s 65
>
t shift 0aA-_
e -982641188
r -800848978
R
e 330905968
r -1801395041
r -45203544
r 969944705
s -1266939812
s 1071587255
r 2070384319
t hwadna7 Aa0-_
s 61910453
R
t UDjUn 0aA-_
r -1700764381
R
R
s 24255491
e 459973519
r 859083917
r -2140614363
r -307172264
R
s 1636924065
r 594168238
e 342788075
s 1232619296
s -1202923071
s 297886161
s 399714127
t else 0aA-_
s -2138817396
s 1123509674
r -82914077
r 2061406551
r 686585324
s 1968971545
2 changes: 1 addition & 1 deletion source/definitions.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
#define DEF_SEND_APP_INFO_URL (std::string)"https://script.google.com/macros/s/AKfycbyn_blFyKWXCgJr6NIF8x6ETs7CHRN5FXKYEAAIrzV6jPYcCkI/exec"
#define DEF_CHECK_UPDATE_URL (std::string)"https://script.google.com/macros/s/AKfycbwTd3jzV0npUE9MNKmZIv3isazVR5D9_7A8rexsG1vr9SE7iavDBxgtzlph8dZipwu9/exec"
#define DEF_HTTP_USER_AGENT (std::string)"video player for 3ds v1.1.0"
#define DEF_CURRENT_APP_VER (std::string)"0.5.2"
#define DEF_CURRENT_APP_VER (std::string)"0.5.3"
#define DEF_CURRENT_APP_VER_INT 0
#define GITHUB_URL std::string("https://github.com/windows-server-2003/ThirdTube")

Expand Down
14 changes: 8 additions & 6 deletions source/network_decoder/network_decoder_multiple.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "network_decoder_multiple.hpp"
#include "headers.hpp"
#include "youtube_parser/parser.hpp"

void NetworkMultipleDecoder::deinit() {
initer_stop_request = true;
Expand Down Expand Up @@ -72,8 +73,8 @@ Result_with_string NetworkMultipleDecoder::init(std::string video_url, std::stri
NetworkDecoderFFmpegIOData tmp_ffmpeg_data;
std::vector<NetworkStream *> streams;
if (video_audio_seperate) {
NetworkStream *video_stream = new NetworkStream(video_url + url_append, is_livestream, NULL);
NetworkStream *audio_stream = new NetworkStream(audio_url + url_append, is_livestream, NULL);
NetworkStream *video_stream = new NetworkStream(video_url + url_append, extract_stream_length(video_url), is_livestream, NULL);
NetworkStream *audio_stream = new NetworkStream(audio_url + url_append, extract_stream_length(audio_url), is_livestream, NULL);
streams = {video_stream, audio_stream};
downloader.add_stream(video_stream);
downloader.add_stream(audio_stream);
Expand All @@ -85,7 +86,7 @@ Result_with_string NetworkMultipleDecoder::init(std::string video_url, std::stri
video_url = get_base_url(video_stream->url);
audio_url = get_base_url(audio_stream->url);
} else {
NetworkStream *both_stream = new NetworkStream(both_url + url_append, is_livestream, NULL);
NetworkStream *both_stream = new NetworkStream(both_url + url_append, extract_stream_length(both_url), is_livestream, NULL);
streams = { both_stream };
downloader.add_stream(both_stream);
decoder.interrupt = false;
Expand Down Expand Up @@ -244,9 +245,10 @@ void NetworkMultipleDecoder::livestream_initer_thread_func() {
logger.info("net/live-init", "next : " + std::to_string(seq_next));

NetworkDecoderFFmpegIOData tmp_ffmpeg_data;
std::string url_prefix = "&sq=" + std::to_string(seq_next);
if (video_audio_seperate) {
NetworkStream *video_stream = new NetworkStream(video_url + "&sq=" + std::to_string(seq_next), is_livestream, NULL);
NetworkStream *audio_stream = new NetworkStream(audio_url + "&sq=" + std::to_string(seq_next), is_livestream, NULL);
NetworkStream *video_stream = new NetworkStream(video_url + url_prefix, extract_stream_length(video_url), is_livestream, NULL);
NetworkStream *audio_stream = new NetworkStream(audio_url + url_prefix, extract_stream_length(audio_url), is_livestream, NULL);
video_stream->disable_interrupt = audio_stream->disable_interrupt = true;
downloader->add_stream(video_stream);
downloader->add_stream(audio_stream);
Expand Down Expand Up @@ -278,7 +280,7 @@ void NetworkMultipleDecoder::livestream_initer_thread_func() {
}
video_stream->disable_interrupt = audio_stream->disable_interrupt = false;
} else {
NetworkStream *both_stream = new NetworkStream(both_url + "&sq=" + std::to_string(seq_next), is_livestream, NULL);
NetworkStream *both_stream = new NetworkStream(both_url + url_prefix, extract_stream_length(both_url), is_livestream, NULL);
both_stream->disable_interrupt = true;
downloader->add_stream(both_stream);
Result_with_string result = tmp_ffmpeg_data.init(both_stream, &decoder);
Expand Down
22 changes: 18 additions & 4 deletions source/network_decoder/network_downloader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,17 @@ static void confirm_thread_network_session_list_inited() {
}
}

static std::string remove_url_parameter(const std::string &url, const std::string &param) {
std::string res;
for (size_t i = 0; i < url.size(); ) {
if (url[i] == '&' || url[i] == '?') {
if (url.substr(i + 1, param.size() + 1) == param + "=") {
i = std::find(url.begin() + i + 1, url.end(), '&') - url.begin();
} else res.push_back(url[i++]);
} else res.push_back(url[i++]);
}
return res;
}

#define LOG_THREAD_STR "net/dl"
void NetworkStreamDownloader::downloader_thread() {
Expand Down Expand Up @@ -238,12 +249,15 @@ void NetworkStreamDownloader::downloader_thread() {
u64 expected_len = end - start;

auto &session_list = cur_stream->session_list ? *cur_stream->session_list : thread_network_session_list;
auto result = session_list.perform(HttpRequest::GET(cur_stream->url, {{"Range", "bytes=" + std::to_string(start) + "-" + std::to_string(end - 1)}}));
if (result.redirected_url != "") cur_stream->url = result.redirected_url;
// length not sure -> use Range header to get the size (slower)
auto result = cur_stream->len == 0 ?
session_list.perform(HttpRequest::GET(cur_stream->url, {{"Range", "bytes=" + std::to_string(start) + "-" + std::to_string(end - 1)}})) :
session_list.perform(HttpRequest::GET(cur_stream->url + "&range=" + std::to_string(start) + "-" + std::to_string(end - 1), {}));
if (result.redirected_url != "") cur_stream->url = remove_url_parameter(result.redirected_url, "range");


if (!result.fail && result.status_code_is_success()) {
if (!cur_stream->ready) {
if (cur_stream->len == 0) {
auto content_range_str = result.get_header("Content-Range");
char *slash = strchr(content_range_str.c_str(), '/');
bool ok = false;
Expand All @@ -252,7 +266,7 @@ void NetworkStreamDownloader::downloader_thread() {
cur_stream->len = strtoll(slash + 1, &end, 10);
if (!*end) {
ok = true;
cur_stream->block_num = (cur_stream->len + BLOCK_SIZE - 1) / BLOCK_SIZE;
cur_stream->block_num = NetworkStream::get_block_num(cur_stream->len);
} else logger.error(LOG_THREAD_STR, "failed to parse Content-Range : " + std::string(slash + 1));
} else logger.error(LOG_THREAD_STR, "no slash in Content-Range response header : " + content_range_str);
if (!ok) cur_stream->error = true;
Expand Down
9 changes: 6 additions & 3 deletions source/network_decoder/network_downloader.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,17 @@ struct NetworkStream {
static constexpr u64 NEW3DS_MAX_CACHE_BLOCKS = 12 * 1000 * 1000 / BLOCK_SIZE;
static constexpr u64 OLD3DS_MAX_CACHE_BLOCKS = 4 * 1000 * 1000 / BLOCK_SIZE;
static constexpr int RETRY_CNT_MAX = 1;
static u64 get_block_num(u64 size) { return (size + BLOCK_SIZE - 1) / BLOCK_SIZE; }

u64 block_num = 0;
std::string url;
Mutex downloaded_data_lock; // std::map needs locking when searching and inserting at the same time
u64 len = 0;
u64 block_num = 0;
std::map<u64, std::vector<u8> > downloaded_data;
bool whole_download = false;
NetworkSessionList *session_list = NULL;

// anything above here is not supposed to be used from outside network_downloader.cpp and network_downloader.hpp
u64 len = 0;
volatile bool ready = false;
volatile bool suspend_request = false;
volatile bool quit_request = false;
Expand All @@ -37,8 +38,10 @@ struct NetworkStream {
bool livestream_private = false;
bool read_dead_tried = false;


// if `whole_download` is true, it will not use Range request but download the whole content at once (used for livestreams)
NetworkStream (std::string url, bool whole_download, NetworkSessionList *session_list) : url(url), whole_download(whole_download), session_list(session_list) {}
NetworkStream (std::string url, int64_t len, bool whole_download, NetworkSessionList *session_list) : url(url), len(len < 0 ? 0 : len),
block_num(get_block_num(this->len)), whole_download(whole_download), session_list(session_list) {}

double get_download_percentage();
std::vector<double> get_buffering_progress_bar(int res_len);
Expand Down
1 change: 1 addition & 0 deletions source/youtube_parser/parser.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,7 @@ std::string get_video_id_from_thumbnail_url(const std::string &url);
bool youtube_is_valid_video_id(const std::string &id);
bool is_youtube_url(const std::string &url);
bool is_youtube_thumbnail_url(const std::string &url);
int64_t extract_stream_length(const std::string &url);

enum class YouTubePageType {
VIDEO,
Expand Down
9 changes: 9 additions & 0 deletions source/youtube_parser/utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -67,4 +67,13 @@ YouTubePageType youtube_get_page_type(std::string url) {
if (starts_with(url, "https://m.youtube.com/results?", 0)) return YouTubePageType::SEARCH;
return YouTubePageType::INVALID;
}
int64_t extract_stream_length(const std::string &url) {
auto pos = url.find("&clen=");
if (pos == std::string::npos) pos = url.find("?clen=");
if (pos == std::string::npos) return -1;
pos += std::string("&clen=").size();
int64_t res = 0;
while (pos < url.size() && isdigit(url[pos])) res = res * 10 + url[pos++] - '0';
return res;
}

3 changes: 1 addition & 2 deletions source/youtube_parser/video.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@ static bool extract_player_data(Document &json_root, RJson player_response, YouT

url = url.substr(0, n_start) + next_n + url.substr(n_end, url.size() - n_end);
if (url.find("ratebypass") == std::string::npos) url += "&ratebypass=yes";

i.set_str(json_root, "url", url.c_str());
}
for (auto &i : formats) i.set_str(json_root, "url", url_decode(i["url"].string_value()).c_str()); // something like %2C still appears in the url, so decode them back
Expand Down Expand Up @@ -302,7 +301,7 @@ YouTubeVideoDetail youtube_load_video_page(std::string url) {
# ifdef _WIN32
// for debug purpose, to check whether the extracted stream url is working
if (res.audio_stream_url != "") {
auto tmp_data = http_get(res.audio_stream_url, {{"Range", "bytes=0-400000"}}).second;
auto tmp_data = http_get(res.audio_stream_url + "&range=0-400000").second;
if (tmp_data.size() != 400001) {
debug_error("!!!!!!!!!!!!!!!!!!!!! SIZE DIFFER : " + std::to_string(tmp_data.size()) + " !!!!!!!!!!!!!!!!!!!!!");
} else debug_info("----------------------- OK -----------------------");
Expand Down

0 comments on commit 0fa8674

Please sign in to comment.