Linkvertise Bypass with Cool GUI

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})();
Linkvertise Bypass with Cool GUI | Robomonkey