Skip to content

Instantly share code, notes, and snippets.

@RellikJaeger
Last active July 31, 2024 19:13
Show Gist options
  • Save RellikJaeger/cdbf58eec030a87235fd20703527ff0f to your computer and use it in GitHub Desktop.
Save RellikJaeger/cdbf58eec030a87235fd20703527ff0f to your computer and use it in GitHub Desktop.
AnimePahe auto downloader for Tampermonkey
// ==UserScript==
// @name AnimePahe auto downloader
// @namespace https://gist.github.com/RellikJaeger/cdbf58eec030a87235fd20703527ff0f
// @version 0.5.4
// @description AnimePahe auto downloader
// @author Rellik Jaeger
// @match https://animepahe.com/play/*/*
// @match https://animepahe.org/play/*/*
// @match https://animepahe.ru/play/*/*
// @match https://pahe.win/*
// @match https://kwik.cx/f/*
// @match https://kwik.si/f/*
// @match https://animepahe.com/*
// @match https://animepahe.ru/*
// @match https://animepahe.org/*
// @icon https://animepahe.com/pikacon.ico
// @grant none
// ==/UserScript==
(function () {
'use strict';
let bruteForce;
let retryCount = 1;
switch (window.location.host) {
case 'animepahe.com':
case 'animepahe.org':
case 'animepahe.ru':
if (window.location.pathname === '/') {
var fontName = 'Nabla';
// Create a link element for Google Fonts
var linkElement = document.createElement('link');
linkElement.href = 'https://fonts.googleapis.com/css2?family=' + fontName + '&display=swap';
linkElement.rel = 'stylesheet';
// Append the link element to the head of the document
document.head.appendChild(linkElement);
var searchForm = document.querySelector('.nav-search');
var searchBox = document.querySelector('.input-search');
searchForm.style.margin = '10px';
searchBox.style.color = 'white';
searchBox.style.background = '#222';
searchBox.style.border = 'solid 2px #C3295C';
searchBox.style.borderRadius = '10px';
var button = document.querySelector('#loginBtn');
var buttonWrapper = document.querySelector('#btnWrapper');
if (!button) {
button = document.createElement('button');
buttonWrapper = document.createElement('div');
buttonWrapper.setAttribute('id', 'btnWrapper');
buttonWrapper.appendChild(button);
buttonWrapper.style.display = 'flex';
buttonWrapper.style.justifyContent = 'flex-end';
button.textContent = 'Login';
button.setAttribute('id', 'loginBtn');
}
var navbarNavDropdown = document.querySelector('#navbarNavDropdown');
navbarNavDropdown.appendChild(buttonWrapper);
button.style.width = '90px';
button.style.margin = '10px';
button.style.borderRadius = '5px';
button.style.border = 'solid thin gold';
button.style.padding = '5px 10px 7px 10px';
button.style.fontFamily = fontName;
button.style.backgroundColor = '#222';
button.addEventListener('mouseenter', function () {
button.style.backgroundColor = '#444';
});
button.addEventListener('mouseleave', function () {
button.style.backgroundColor = '#222';
});
button.addEventListener('click', function () {
notifyMe();
});
return;
}
bruteForce = setInterval(() => takeOver(), 600 * retryCount++);
break;
case 'pahe.win':
bruteForce = setInterval(() => timerBypass(), 700 * retryCount++);
break;
case 'kwik.cx':
case 'kwik.si':
if (document.title.includes('Please Wait...') || document.title.includes('Just a moment...')) {
bruteForce = setInterval(() => autoDownload(), 4000 * retryCount++);
} else {
bruteForce = setInterval(() => autoDownload(), 600 * retryCount++);
}
break;
}
function notifyMe() {
if (!("Notification" in window)) {
// Check if the browser supports notifications
alert("This browser does not support desktop notification");
} else if (Notification.permission === "granted") {
// Check whether notification permissions have already been granted;
// if so, create a notification
const notification = new Notification("Hi there!");
// …
} else if (Notification.permission !== "denied") {
// We need to ask the user for permission
Notification.requestPermission().then((permission) => {
// If the user accepts, let's create a notification
if (permission === "granted") {
const notification = new Notification("Hi there!");
// …
}
});
}
// At last, if the user has denied notifications, and you
// want to be respectful there is no need to bother them anymore.
}
function takeOver() {
try {
let recommended = document.querySelector('#fansubMenu').firstChild.data.trim().normalize('NFC');
let pickDownload = document.querySelector('#pickDownload');
let downloadButtonEndPoint = pickDownload.children.length;
let badgesPrimary = document.getElementsByClassName('badge badge-primary');
let badgesWarning = document.getElementsByClassName('badge badge-warning');
let mikuCheckPoint;
for (let i = 0; i < downloadButtonEndPoint; i++) {
let button = document.createElement('div');
let url = pickDownload.children[i].href;
button.style.color = '#111';
button.style.background = '#fff';
button.style.width = pickDownload.style.width;
button.style.cursor = 'url(""), auto';
button.style.boxSizing = 'border-box';
button.style.paddingTop = '4px';
button.style.paddingBottom = '4px';
button.style.display = 'flex';
button.style.justifyContent = 'center';
button.style.fontSize = '14px';
if (pickDownload.children[i].firstChild.data.trim().normalize('NFC').includes(recommended) &&
!pickDownload.children[i].firstChild.data.trim().normalize('NFC').includes('eng')) {
button.title = 'Recommended by Miku';
button.innerHTML = '<img src="" width="24px" height="24px" alt="Recommended by Miku">⬇️ ' + pickDownload.children[i].innerHTML;
mikuCheckPoint = `Index ${i}: ${pickDownload.children[i].innerHTML}`;
} else if (!button.innerHTML.normalize('NFC').includes('⬇️ '.normalize('NFC'))) {
button.innerHTML = '⬇️ ' + pickDownload.children[i].innerHTML;
}
button.onclick = (event) => { // eslint-disable-line
event.stopPropagation();
window.open(url, '_blank');
$('#episodeMenu').dropdown('toggle'); // eslint-disable-line
};
button.onmouseenter = () => {
button.style.color = '#fff';
button.style.background = '#D5015B';
};
button.onmouseleave = () => {
button.style.color = '#111';
button.style.background = '#fff';
};
pickDownload.children[i].replaceWith(button);
if (pickDownload.children[i].children[0] !== undefined && pickDownload.children[i].children[0].tagName === 'SPAN') {
pickDownload.children[i].children[0].style.margin = '3px 4px 4px 4px';
console.log('span changed');
}
if (pickDownload.children[i].children[1] !== undefined && pickDownload.children[i].children[1].tagName === 'SPAN') {
pickDownload.children[i].children[1].style.margin = '3px 4px 4px 4px';
console.log('span changed');
}
}
for (let i = 0; i < badgesPrimary.length; i++) {
badgesPrimary[i].style.height = '16px';
}
for (let i = 0; i < badgesWarning.length; i++) {
badgesWarning[i].style.height = '16px';
}
if (pickDownload.children[--downloadButtonEndPoint].nodeName === 'DIV' && mikuCheckPoint !== undefined) {
clearInterval(bruteForce);
$('#downloadMenu').dropdown('toggle'); // eslint-disable-line
console.log('Miku check point: ' + mikuCheckPoint);
}
} catch (error) {
console.log('Error: ' + error);
}
}
function timerBypass() {
let scripts = document.head.getElementsByTagName('script');
for (let i = 0; i < scripts.length; i++) {
if (scripts[i].innerHTML.includes('https://')) {
window.location = scripts[i].innerHTML.match(/(https?:\/\/[^ "]*)/)[0];
clearInterval(bruteForce);
break;
}
}
}
function autoDownload() {
clearInterval(bruteForce);
let downloadButton = document.querySelector('button[type="submit"]');
if (downloadButton != undefined) {
downloadButton.form.submit();
// fetch('https://hub.dummyapis.com/delay?seconds=9').then(response => setTimeout(() => window.close(), 1000));
} else {
// setTimeout(() => window.location.reload(), 10000);
}
}
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment