您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Implemented adblock, automatically extends the server time and automatically starts the server.
- // ==UserScript==
- // @name Aternos Ultimate Script 2024
- // @namespace Mite's Scripts
- // @version 1.0.1
- // @description Implemented adblock, automatically extends the server time and automatically starts the server.
- // @author Mite
- // @license MIT
- // @match https://aternos.org/*
- // @icon https://upload.wikimedia.org/wikipedia/commons/thumb/1/10/Userbox_creeper.svg/567px-Userbox_creeper.svg.png
- // @grant none
- // @run-at document-start
- // ==/UserScript==
- (function() {
- 'use strict';
- // Overriding Date.now to prevent adblock detection
- let oldDateNow = Date.now;
- unsafeWindow.Date.now = function () {
- try {
- throw new Error();
- } catch (e) {
- if (e.stack.includes('data:text/javascript')) {
- throw new Error();
- } else {
- return oldDateNow();
- }
- }
- };
- // Intersection Observer to handle extend button
- const extendButtonObserver = new IntersectionObserver(handleIntersection, {
- root: null,
- rootMargin: '0px',
- threshold: 0.1
- });
- function handleIntersection(entries, observer) {
- entries.forEach(entry => {
- if (entry.isIntersecting) {
- const extendButton = entry.target;
- if (extendButton.textContent.trim().toLowerCase() !== "stop") {
- extendButton.click();
- }
- observer.unobserve(extendButton);
- }
- });
- }
- // Function to observe extend button visibility
- function checkButtonVisibility() {
- const extendButton = document.querySelector('.btn.btn-tiny.btn-success.server-extend-end');
- if (extendButton) {
- extendButtonObserver.observe(extendButton);
- } else {
- console.error('[Aternos Extend Server Time] Button not found.');
- }
- }
- // Function to check the timer and extend server time at 0:30
- function checkTimerAndExtend() {
- const timerElement = document.querySelector('.server-end-countdown');
- if (timerElement) {
- const timerValue = timerElement.textContent.trim();
- if (timerValue === '0:30') {
- const extendButton = document.querySelector('.btn.btn-tiny.btn-success.server-extend-end');
- if (extendButton && extendButton.textContent.trim().toLowerCase() !== "stop") {
- extendButton.click();
- }
- }
- }
- }
- // Function to check for white screen and refresh the page if detected
- function checkForWhiteScreen() {
- const whiteScreenElement = document.querySelector('.white-screen-element');
- if (whiteScreenElement) {
- console.error('[Aternos White Screen] White screen detected. Refreshing page...');
- window.location.reload();
- }
- }
- // Function to check if the server is offline and click the "Start" button if it is
- function checkAndStartServerIfOffline() {
- const serverStatus = document.querySelector('.server-actions');
- if (serverStatus && serverStatus.classList.contains('offline')) {
- const startButton = document.querySelector('#start');
- if (startButton && startButton.offsetParent !== null) {
- startButton.click();
- }
- }
- }
- // Function to click the "No" button if the alert dialog is present
- function clickNoButtonIfAlertPresent() {
- const alertDialog = document.querySelector('dialog.alert.alert-danger');
- if (alertDialog && alertDialog.open) {
- const noButton = alertDialog.querySelector('.btn-danger');
- if (noButton) {
- noButton.click();
- }
- }
- }
- // Set up intervals to check continuously
- const checkInterval = 1000; // 1 second
- setInterval(checkButtonVisibility, checkInterval);
- setInterval(checkTimerAndExtend, checkInterval);
- setInterval(checkForWhiteScreen, checkInterval);
- setInterval(checkAndStartServerIfOffline, checkInterval);
- setInterval(clickNoButtonIfAlertPresent, checkInterval);
- })();