Automatically bypass Linkvertise links with a stylish GUI and countdown timer
Size
35.4 KB
Version
1.0.1
Created
Oct 30, 2025
Updated
15 days ago
1// ==UserScript==
2// @name Linkvertise Bypass with Cool GUI
3// @description Automatically bypass Linkvertise links with a stylish GUI and countdown timer
4// @version 1.0.1
5// @match https://*.linkvertise.com/*
6// @match https://linkvertise.com/*
7// @icon 
8// @grant GM.getValue
9// @grant GM.setValue
10// @grant GM.openInTab
11// ==/UserScript==
12(function() {
13 'use strict';
14
15 console.log('Linkvertise Bypass - Extension loaded');
16
17 // Configuration
18 const BYPASS_DELAY = 5; // seconds countdown before bypass
19 const API_BASE = 'https://bypass.pm/bypass2?url=';
20
21 // Create stylish GUI
22 function createBypassGUI() {
23 // Remove any existing GUI
24 const existingGUI = document.getElementById('linkvertise-bypass-gui');
25 if (existingGUI) {
26 existingGUI.remove();
27 }
28
29 // Create main container
30 const guiContainer = document.createElement('div');
31 guiContainer.id = 'linkvertise-bypass-gui';
32 guiContainer.innerHTML = `
33 <div class="bypass-card">
34 <div class="bypass-header">
35 <div class="bypass-icon">⚡</div>
36 <h2>Linkvertise Bypass</h2>
37 </div>
38 <div class="bypass-body">
39 <div class="status-indicator">
40 <div class="pulse-ring"></div>
41 <div class="pulse-dot"></div>
42 </div>
43 <p class="bypass-status">Preparing bypass...</p>
44 <div class="countdown-container">
45 <svg class="countdown-svg" viewBox="0 0 100 100">
46 <circle class="countdown-bg" cx="50" cy="50" r="45"></circle>
47 <circle class="countdown-progress" cx="50" cy="50" r="45"></circle>
48 </svg>
49 <div class="countdown-text">
50 <span class="countdown-number">${BYPASS_DELAY}</span>
51 <span class="countdown-label">seconds</span>
52 </div>
53 </div>
54 <div class="bypass-info">
55 <p>🔒 Bypassing Linkvertise protection</p>
56 <p>🚀 Redirecting to destination...</p>
57 </div>
58 </div>
59 <div class="bypass-footer">
60 <button class="bypass-btn" id="bypass-now-btn">Bypass Now</button>
61 </div>
62 </div>
63 `;
64
65 // Add styles
66 const styles = document.createElement('style');
67 styles.textContent = `
68 #linkvertise-bypass-gui {
69 position: fixed;
70 top: 50%;
71 left: 50%;
72 transform: translate(-50%, -50%);
73 z-index: 999999;
74 font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
75 }
76
77 .bypass-card {
78 background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
79 border-radius: 20px;
80 padding: 30px;
81 box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
82 min-width: 400px;
83 animation: slideIn 0.5s ease-out;
84 }
85
86 @keyframes slideIn {
87 from {
88 opacity: 0;
89 transform: translateY(-30px);
90 }
91 to {
92 opacity: 1;
93 transform: translateY(0);
94 }
95 }
96
97 .bypass-header {
98 display: flex;
99 align-items: center;
100 gap: 15px;
101 margin-bottom: 25px;
102 }
103
104 .bypass-icon {
105 font-size: 40px;
106 animation: pulse 2s infinite;
107 }
108
109 @keyframes pulse {
110 0%, 100% { transform: scale(1); }
111 50% { transform: scale(1.1); }
112 }
113
114 .bypass-header h2 {
115 color: #ffffff;
116 margin: 0;
117 font-size: 28px;
118 font-weight: 700;
119 }
120
121 .bypass-body {
122 text-align: center;
123 color: #ffffff;
124 }
125
126 .status-indicator {
127 position: relative;
128 width: 60px;
129 height: 60px;
130 margin: 0 auto 20px;
131 }
132
133 .pulse-ring {
134 position: absolute;
135 width: 100%;
136 height: 100%;
137 border: 3px solid rgba(255, 255, 255, 0.5);
138 border-radius: 50%;
139 animation: pulsate 2s ease-out infinite;
140 }
141
142 @keyframes pulsate {
143 0% {
144 transform: scale(0.5);
145 opacity: 1;
146 }
147 100% {
148 transform: scale(1.2);
149 opacity: 0;
150 }
151 }
152
153 .pulse-dot {
154 position: absolute;
155 top: 50%;
156 left: 50%;
157 transform: translate(-50%, -50%);
158 width: 30px;
159 height: 30px;
160 background: #ffffff;
161 border-radius: 50%;
162 box-shadow: 0 0 20px rgba(255, 255, 255, 0.8);
163 }
164
165 .bypass-status {
166 font-size: 18px;
167 font-weight: 600;
168 margin-bottom: 25px;
169 color: #ffffff;
170 }
171
172 .countdown-container {
173 position: relative;
174 width: 150px;
175 height: 150px;
176 margin: 0 auto 25px;
177 }
178
179 .countdown-svg {
180 transform: rotate(-90deg);
181 width: 100%;
182 height: 100%;
183 }
184
185 .countdown-bg {
186 fill: none;
187 stroke: rgba(255, 255, 255, 0.2);
188 stroke-width: 8;
189 }
190
191 .countdown-progress {
192 fill: none;
193 stroke: #ffffff;
194 stroke-width: 8;
195 stroke-linecap: round;
196 stroke-dasharray: 283;
197 stroke-dashoffset: 0;
198 transition: stroke-dashoffset 1s linear;
199 }
200
201 .countdown-text {
202 position: absolute;
203 top: 50%;
204 left: 50%;
205 transform: translate(-50%, -50%);
206 text-align: center;
207 }
208
209 .countdown-number {
210 display: block;
211 font-size: 48px;
212 font-weight: 700;
213 color: #ffffff;
214 line-height: 1;
215 }
216
217 .countdown-label {
218 display: block;
219 font-size: 14px;
220 color: rgba(255, 255, 255, 0.8);
221 margin-top: 5px;
222 }
223
224 .bypass-info {
225 margin: 20px 0;
226 padding: 15px;
227 background: rgba(255, 255, 255, 0.1);
228 border-radius: 10px;
229 backdrop-filter: blur(10px);
230 }
231
232 .bypass-info p {
233 margin: 8px 0;
234 font-size: 14px;
235 color: #ffffff;
236 }
237
238 .bypass-footer {
239 margin-top: 25px;
240 }
241
242 .bypass-btn {
243 width: 100%;
244 padding: 15px;
245 background: #ffffff;
246 color: #667eea;
247 border: none;
248 border-radius: 10px;
249 font-size: 16px;
250 font-weight: 700;
251 cursor: pointer;
252 transition: all 0.3s ease;
253 box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
254 }
255
256 .bypass-btn:hover {
257 transform: translateY(-2px);
258 box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
259 background: #f0f0f0;
260 }
261
262 .bypass-btn:active {
263 transform: translateY(0);
264 }
265
266 .bypass-btn:disabled {
267 opacity: 0.6;
268 cursor: not-allowed;
269 }
270 `;
271
272 document.head.appendChild(styles);
273 document.body.appendChild(guiContainer);
274
275 return guiContainer;
276 }
277
278 // Update countdown display
279 function updateCountdown(seconds, progressCircle, numberElement) {
280 const circumference = 283;
281 const offset = circumference - (seconds / BYPASS_DELAY) * circumference;
282 progressCircle.style.strokeDashoffset = offset;
283 numberElement.textContent = seconds;
284 }
285
286 // Perform the bypass
287 async function performBypass() {
288 console.log('Starting Linkvertise bypass...');
289
290 const currentUrl = window.location.href;
291 const bypassUrl = API_BASE + encodeURIComponent(currentUrl);
292
293 try {
294 const statusElement = document.querySelector('.bypass-status');
295 if (statusElement) {
296 statusElement.textContent = 'Fetching destination...';
297 }
298
299 console.log('Fetching bypass URL:', bypassUrl);
300
301 const response = await GM.xmlhttpRequest({
302 method: 'GET',
303 url: bypassUrl,
304 timeout: 15000
305 });
306
307 console.log('Bypass API response:', response.responseText);
308
309 if (response.responseText) {
310 const data = JSON.parse(response.responseText);
311
312 if (data.destination) {
313 console.log('Destination found:', data.destination);
314
315 if (statusElement) {
316 statusElement.textContent = 'Redirecting...';
317 }
318
319 // Wait a moment then redirect
320 setTimeout(() => {
321 console.log('Opening destination URL...');
322 GM.openInTab(data.destination, false);
323
324 // Close current tab after a short delay
325 setTimeout(() => {
326 window.close();
327 }, 1000);
328 }, 500);
329 } else {
330 throw new Error('No destination URL found');
331 }
332 } else {
333 throw new Error('Empty response from bypass API');
334 }
335 } catch (error) {
336 console.error('Bypass failed:', error);
337
338 const statusElement = document.querySelector('.bypass-status');
339 if (statusElement) {
340 statusElement.textContent = '❌ Bypass failed. Trying alternative method...';
341 statusElement.style.color = '#ffcccc';
342 }
343
344 // Try alternative method - extract from page
345 tryAlternativeBypass();
346 }
347 }
348
349 // Alternative bypass method
350 function tryAlternativeBypass() {
351 console.log('Trying alternative bypass method...');
352
353 // Look for the "Get Link" button and click it
354 const getButton = document.querySelector('button[data-testid="lv-button"]');
355 if (getButton && getButton.textContent.includes('Get Link')) {
356 console.log('Found Get Link button, clicking...');
357 getButton.click();
358
359 // Monitor for URL changes
360 const originalUrl = window.location.href;
361 const checkInterval = setInterval(() => {
362 if (window.location.href !== originalUrl) {
363 console.log('URL changed, checking for destination...');
364 clearInterval(checkInterval);
365
366 // Check if we're on a new page
367 setTimeout(() => {
368 const newButton = document.querySelector('button[data-testid="lv-button"]');
369 if (newButton) {
370 newButton.click();
371 }
372 }, 2000);
373 }
374 }, 500);
375
376 // Clear interval after 30 seconds
377 setTimeout(() => clearInterval(checkInterval), 30000);
378 }
379 }
380
381 // Start the bypass process
382 async function startBypass() {
383 console.log('Initializing bypass GUI...');
384
385 const gui = createBypassGUI();
386 const progressCircle = gui.querySelector('.countdown-progress');
387 const numberElement = gui.querySelector('.countdown-number');
388 const bypassButton = gui.querySelector('#bypass-now-btn');
389
390 let countdown = BYPASS_DELAY;
391
392 // Update countdown every second
393 const countdownInterval = setInterval(() => {
394 countdown--;
395 updateCountdown(countdown, progressCircle, numberElement);
396
397 if (countdown <= 0) {
398 clearInterval(countdownInterval);
399 performBypass();
400 }
401 }, 1000);
402
403 // Allow manual bypass
404 bypassButton.addEventListener('click', () => {
405 clearInterval(countdownInterval);
406 bypassButton.disabled = true;
407 bypassButton.textContent = 'Bypassing...';
408 performBypass();
409 });
410 }
411
412 // Initialize when page loads
413 function init() {
414 console.log('Linkvertise Bypass - Initializing...');
415
416 // Wait for page to be fully loaded
417 if (document.readyState === 'loading') {
418 document.addEventListener('DOMContentLoaded', startBypass);
419 } else {
420 startBypass();
421 }
422 }
423
424 // Start the extension
425 init();
426})();