// ==UserScript==
// @name Github 增强 - 高速下载
// @version 1.1.1
// @author X.I.U
// @description 为 Github 的 Clone、Release、Raw、Code(ZIP) 添加高速下载
// @match https://github.com/*/*
// @match https://github.com/*/*/releases
// @match https://github.com/*/*/releases/*
// @icon https://github.githubassets.com/favicon.ico
// @require https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js
// @license GPL-3.0 License
// @run-at document-end
// @namespace https://greasyfork.org/scripts/412245
// @downloadURL none
// ==/UserScript==
(function() {
var download_url1 = "https://download.fastgit.org";
var download_url1_name = "日本东京";
var download_url2 = "https://gh.con.sh";
var download_url2_name = "美国 01";
var download_url3 = "https://gh.api.99988866.xyz";
var download_url3_name = "美国 02";
var download_url4 = "https://g.ioiox.com";
var download_url4_name = "中国香港";
var download_url5 = "https://git.yumenaka.net";
var download_url5_name = "美国洛杉矶"; // 支持 Raw 加速
var clone_url1 = "https://hub.fastgit.org"; // 中国香港
var clone_url2 = "https://gitclone.com"; // 中国浙江杭州
var clone_url3 = "https://github.com.cnpmjs.org"; // 新加坡
var raw_fast = "中国国内"; // 指定各个文件名后的云朵使用的高速下载链接,选择范围:[Github、中国国内、中国香港、美国洛杉矶],各加速源注意事项看下面注释
var raw_url0 = "https://raw.githubusercontent.com";
var raw_url0_name = "Github"; // 原生链接
var raw_url1 = "https://cdn.jsdelivr.net";
var raw_url1_name = "中国国内"; // 注意:当该项目当前分支总文件大小超过 50MB 时,高速下载链接不可用。注意:当前分支名为版本号格式时(如 v1.2.3),高速下载链接因格式限制不可用。
var raw_url2 = "https://raw.fastgit.org";
var raw_url2_name = "中国香港"; // 注意:单个文件太大时可能会提示超时,可以重试。
var download_zip_svg = ``;
var download_clone_svg = ``
var raw_svg = ``
var download_release_style = `padding:0 4px;margin-right: -1px;border-radius: 2px;background-color: #ffffff;border-color: rgba(27, 31, 35, 0.1);font-size: 12px;`
addRelease(); // Release 加速
addDownloadZIP(); // Source Code 加速
addGitClone(); // Download ZIP/Code(ZIP) 加速
addRawFile(); // Raw 加速
setTimeout(addDownLink, 2000); // 添加 Raw 下载链接(添加到项目页文件名称后面),延迟 2 秒执行,避免被 pjax 刷掉
$(document).on('pjax:success',function(evt){
addRawFile(); // pjax 事件发生后,添加 Raw 加速按钮 及 Raw 下载链接
setTimeout(addDownLink, 2000); // 延迟 2 秒执行,避免被 pjax 刷掉
});
// Release 加速
function addRelease(){
$(".Box.Box--condensed").each(function () {
$(this).find(".d-flex.Box-body>a").each(function () {
var href = $(this).attr("href");
var url1 = download_url1 + href;
var url2 = download_url2 + '/github.com' + href;
var url3 = download_url3 + '/github.com' + href;
var url4 = download_url4 + '/github.com' + href;
var url5 = download_url5 + '/github.com' + href;
var html1 = `
`;
$(this).after(html1);
});
// Source Code 加速
$(this).find(".d-block.Box-body>a").each(function () {
var href = $(this).attr("href");
var url1 = download_url1 + href;
var url2 = download_url2 + '/github.com' + href;
var url3 = download_url3 + '/github.com' + href;
var url4 = download_url4 + '/github.com' + href;
var url5 = download_url5 + '/github.com' + href;
var html1 = ``;
$(this).after(html1);
});
// 修改 Source code 样式,使其和加速按钮并列一排
document.querySelectorAll('.d-block.py-1.py-md-2.Box-body.px-2').forEach(el=>el.className='d-flex py-1 py-md-2 Box-body px-2');
});
}
// Download ZIP 加速
function addDownloadZIP(){
$(".dropdown-menu.dropdown-menu-sw.p-0 ul li:last-child").each(function () {
var href = $(this).children("a").attr("href");
var url1 = download_url1 + href;
var url2 = download_url2 + "/github.com" + href;
var url3 = download_url3 + "/github.com" + href;
var url4 = download_url4 + "/github.com" + href;
var url5 = download_url5 + "/github.com" + href;
var html1 = `
${download_zip_svg}Download ZIP ${download_url1_name}
${download_zip_svg}Download ZIP ${download_url2_name}
${download_zip_svg}Download ZIP ${download_url3_name}
${download_zip_svg}Download ZIP ${download_url4_name}
${download_zip_svg}Download ZIP ${download_url5_name}
`;
$(this).after(html1);
});
}
// Git Clone 加速
function addGitClone(){
$("[role='tabpanel'] div.input-group").first().each(function () {
var href_split = location.href.split("/");
var url1 = clone_url1 + "/" + href_split[3] + "/" + href_split[4] + ".git";
var url2 = clone_url2 + "/github.com/" + href_split[3] + "/" + href_split[4] + ".git";
var url3 = clone_url3 + "/" + href_split[3] + "/" + href_split[4] + ".git";
var html1 = `
`;
$(this).after(html1);
});
}
// Raw 加速
function addRawFile(){
$("#raw-url").each(function () {
var href = location.href.replace('https://github.com','');
var href2 = href.replace('/blob/','/');
var url1 = raw_url1 + "/gh" + href.replace('/blob/','@');
var url2 = raw_url2 + href2;
var url3 = download_url5 + "/" + raw_url0 + href2;
var html1 = `
${raw_url1_name}
${raw_url2_name}
${download_url5_name}
`;
$(this).after(html1);
});
}
// 添加 Raw 下载链接(添加到项目页文件名称后面)
function addDownLink(){
// 如果不是项目文件页面,就返回
var files = $('.octicon.octicon-file');
if(files.length === 0) return;
var files1 = $('.fileDownLink');
if(files1.length > 0) return;
// 鼠标指向则显示
var mouseOverHandler = function(evt){
var elem = evt.currentTarget,
aElm = elem.querySelectorAll('.fileDownLink');
aElm.forEach(el=>el.style.visibility = 'visible');
};
// 鼠标离开则隐藏
var mouseOutHandler = function(evt){
var elem = evt.currentTarget,
aElm = elem.querySelectorAll('.fileDownLink');
aElm.forEach(el=>el.style.visibility = 'hidden');
};
// 循环添加
files.each(function(i,fileElm){
var trElm = fileElm.parentNode.parentNode,
cntElm = trElm.querySelector('.css-truncate.css-truncate-target.d-block.width-fit a'),
Name = cntElm.innerText,
href = cntElm.attributes["href"].nodeValue.replace('https://github.com','');
// 如果 raw_fast 为 true 则下载链接为高速下载链接,反之为 Github 原生下载链接
var href2 = href.replace('/blob/','/');
var url;
var url_name;
switch(raw_fast)
{
case raw_url0_name:
url = raw_url0 + href2;
url_name = raw_url0_name;
break;
case raw_url1_name:
url = raw_url1 + "/gh" + href.replace('/blob/','@');
url_name = raw_url1_name;
break;
case raw_url2_name:
url = raw_url2 + href2;
url_name = raw_url2_name;
break;
case download_url5_name:
url = download_url5 + "/" + raw_url0 + href2;
url_name = download_url5_name;
break;
}
var html1 = ` ${raw_svg}`;
$(cntElm).after(html1);
// 绑定鼠标事件
trElm.onmouseover=mouseOverHandler;
trElm.onmouseout=mouseOutHandler;
});
}
})();