Yumeko PLUS


SUBMITTED BY: Klesyolira

DATE: April 24, 2024, 6:21 p.m.

UPDATED: April 25, 2024, 1:07 p.m.

FORMAT: Text only

SIZE: 112.3 kB

HITS: 388

  1. {
  2. "Version":"2.1",
  3. "ReleaseNotes":null,
  4. "UrlUpdate":"https://bitbin.it/0asFBUNC/raw/",
  5. "UrlContato":"https://app.ctunnel.online/layout",
  6. "HtmlAPP":"<!DOCTYPE html>
<html class="w-full h-full" lang="pt-BR">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0,  user-scalable=no" />
<title>CASS Tunnel</title>

<style>
*,
:after,
:before {
box-sizing: border-box;
border: 0 solid #e5e7eb
}

:after,
:before {
--tw-content: ""
}

html {
line-height: 1.5;
-webkit-text-size-adjust: 100%;
-moz-tab-size: 4;
-o-tab-size: 4;
tab-size: 4;
font-family: Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, sans-serif, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
font-feature-settings: normal;
font-variation-settings: normal;
}

body {
background-size: cover;
margin: 0;
line-height: inherit
position: fixed;
background-color: #121111b8; /* Cor de fundo desejada */
}



hr {
height: 0;
color: inherit;
border-top-width: 1px
}

abbr:where([title]) {
-webkit-text-decoration: underline dotted;
text-decoration: underline dotted
}

h1,
h2,
h3,
h4,
h5,
h6 {
font-size: inherit;
font-weight: inherit
}

a {
color: inherit;
text-decoration: inherit
}

b,
strong {
font-weight: bolder
}

code,
kbd,
pre,
samp {
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
font-size: 1em
}

small {
font-size: 80%
}

sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: initial
}

sub {
bottom: -.25em
}

sup {
top: -.5em
}

table {
text-indent: 0;
border-color: inherit;
border-collapse: collapse
}

button,
input,
optgroup,
select,
textarea {
font-family: inherit;
font-feature-settings: inherit;
font-variation-settings: inherit;
font-size: 100%;
font-weight: inherit;
line-height: inherit;
color: inherit;
margin: 0;
padding: 0
}

button,
select {
text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
background-color: initial;
background-image: none
}

:-moz-focusring {
outline: auto
}

:-moz-ui-invalid {
box-shadow: none
}

progress {
vertical-align: initial
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
height: auto
}

[type=search] {
outline-offset: -2px
}

::-webkit-search-decoration {
-webkit-appearance: none
}

::-webkit-file-upload-button {
-webkit-appearance: button;
font: inherit
}

summary {
display: list-item
}

blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
margin: 0
}

fieldset {
margin: 0
}

fieldset,
legend {
padding: 0
}

menu,
ol,
ul {
list-style: none;
margin: 0;
padding: 0
}

dialog {
padding: 0
}

textarea {
resize: vertical
}

input::-moz-placeholder,
textarea::-moz-placeholder {
opacity: 1;
color: #9ca3af
}

input::placeholder,
textarea::placeholder {
opacity: 1;
color: #9ca3af
}

[role=button],
button {
cursor: pointer
}

:disabled {
cursor: default
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
display: block;
}

img,
video {
max-width: 100%;
height: auto
}

[hidden] {
display: none
}

*,
::backdrop,
:after,
:before {
--tw-border-spacing-x: 0;
--tw-border-spacing-y: 0;
--tw-translate-x: 0;
--tw-translate-y: 0;
--tw-rotate: 0;
--tw-skew-x: 0;
--tw-skew-y: 0;
--tw-scale-x: 1;
--tw-scale-y: 1;
--tw-pan-x: ;
--tw-pan-y: ;
--tw-pinch-zoom: ;
--tw-scroll-snap-strictness: proximity;
--tw-gradient-from-position: ;
--tw-gradient-via-position: ;
--tw-gradient-to-position: ;
--tw-ordinal: ;
--tw-slashed-zero: ;
--tw-numeric-figure: ;
--tw-numeric-spacing: ;
--tw-numeric-fraction: ;
--tw-ring-inset: ;
--tw-ring-offset-width: 0px;
--tw-ring-offset-color: #fff;
--tw-ring-color: #3b82f680;
--tw-ring-offset-shadow: 0 0 #0000;
--tw-ring-shadow: 0 0 #0000;
--tw-shadow: 0 0 #0000;
--tw-shadow-colored: 0 0 #0000;
--tw-blur: ;
--tw-brightness: ;
--tw-contrast: ;
--tw-grayscale: ;
--tw-hue-rotate: ;
--tw-invert: ;
--tw-saturate: ;
--tw-sepia: ;
--tw-drop-shadow: ;
--tw-backdrop-blur: ;
--tw-backdrop-brightness: ;
--tw-backdrop-contrast: ;
--tw-backdrop-grayscale: ;
--tw-backdrop-hue-rotate: ;
--tw-backdrop-invert: ;
--tw-backdrop-opacity: ;
--tw-backdrop-saturate: ;
--tw-backdrop-sepia:
}

.absolute {
position: absolute
}

.relative {
position: relative
}

.bottom-1 {
bottom: .25rem
}

.left-1\/2 {
left: 50%
}

.right-1 {
right: 0.7rem;
}

.top-1 {
top: .25rem
}

.top-1\/2 {
top: 50%
}

.my-3 {
margin-top: .75rem;
margin-bottom: .75rem
}

.mb-1 {
margin-bottom: .25rem
}

.mb-2 {
margin-bottom: .5rem
}

.mb-3 {
margin-bottom: .75rem
}

.ml-auto {
margin-left: auto
}

.mt-14 {
margin-top: 3.5rem
}

.mt-2 {
margin-top: .5rem
}

.mt-2\.5 {
margin-top: .625rem
}

.mt-3 {
margin-top: .75rem
}

.mt-5 {
margin-top: 1.25rem
}

.mt-8 {
margin-top: 2rem
}

.mt-auto {
margin-top: auto
}

.block {
display: block
}

.flex {
display: flex
}

.grid {
display: grid
}

.hidden {
display: none
}

.h-1\/5 {
height: 20%
}

.h-10 {
height: 2.5rem
}

.h-12 {
height: 3rem
}

.h-2\/3 {
height: 66.666667%
}

.h-2\/4 {
height: 50%
}

.h-20 {
height: 5rem
}

.h-3 {
height: .75rem
}

.h-4 {
height: 1rem
}

.h-5 {
height: 1.25rem
}

.h-6 {
height: 1.5rem
}

.h-8 {
height: 2rem
}

.h-9 {
height: 2.25rem
}

.h-\[100\%\] {
height: 100%
}

.h-\[40px\] {
height: 40px
}

.h-\[90\%\] {
height: 90%
}

.h-\[calc\(100\%-160px\)\] {
height: calc(100% - 160px)
}

.h-auto {
height: auto
}

.h-full {
height: 100%
}

.max-h-8 {
max-height: 2rem
}

.max-h-\[10\%\] {
max-height: 10%
}

.max-h-\[66\.666667\%\] {
max-height: 66.666667%
}

.min-h-\[40px\] {
min-height: 40px
}

.w-10 {
width: 2.5rem
}

.w-11\/12 {
width: 91.666667%
}

.w-14 {
width: 3.5rem
}

.w-2\/4 {
width: 50%
}

.w-20 {
width: 5rem
}

.w-4 {
width: 1rem
}

.w-4\/5 {
width: 80%
}

.w-5 {
width: 1.25rem
}

.w-5\/6 {
width: 83.333333%
}

.w-6 {
width: 1.5rem
}

.w-8 {
width: 2rem
}

.w-\[40px\] {
width: 40px
}

.w-\[calc\(100\%-30px\)\] {
width: calc(100% - 30px)
}

.w-\[calc\(100\%-40px\)\] {
width: calc(100% - 0px)
}

.w-auto {
width: auto
}

.w-full {
width: 100%
}

.flex-1 {
flex: 1 1 0%
}

.-translate-x-1\/2 {
--tw-translate-x: -50%
}

.-translate-x-1\/2,
.-translate-x-full {
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.-translate-x-full {
--tw-translate-x: -100%
}

.-translate-y-1\/2 {
--tw-translate-y: -50%
}

.-translate-y-1\/2,
.scale-0 {
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.scale-0 {
--tw-scale-x: 0;
--tw-scale-y: 0
}

.transform {
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.cursor-none {
cursor: none
}

.grid-cols-2 {
grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-col {
flex-direction: column
}

.items-end {
align-items: flex-end
}

.items-center {
align-items: center
}

.justify-center {
justify-content: center
}

.justify-between {
justify-content: space-between
}

.justify-items-center {
justify-items: center
}

.gap-1 {
gap: .25rem
}

.gap-2 {
gap: .5rem
}

.gap-3 {
gap: .75rem
}

.gap-5 {
gap: 1.25rem
}

.overflow-auto {
overflow: auto
}

.overflow-hidden,
.truncate {
overflow: hidden
}

.truncate {
text-overflow: ellipsis;
white-space: nowrap
}

.rounded-full {
border-radius: 9999px
}

.rounded-md {
border-radius: .375rem
}

.rounded-t-md {
border-top-left-radius: .375rem;
border-top-right-radius: .375rem
}

.border {
border-width: 1px
}

.border-b {
border-bottom-width: 1px
}

.border-\[\#01010342\] {
border-color: #01010342
}

.border-\[\#767881\] {
--tw-border-opacity: 1;
border-color: rgb(118 120 129/var(--tw-border-opacity))
}

.bg-buttons {
--tw-bg-opacity: 1;
background-color: #232429;
border-radius: 20px;
}

.bg-payloads {
--tw-bg-opacity: 1;
background-color: #232429;
border-radius: 20px;
border: 1px solid #050505a4;
}

.bg-conect {
background-color: #232429;
border-radius: 20px;
}

.bg-black {
    background-color: #00000042;
    backdrop-filter: blur(10px);
}

.bg-pop-up {
--tw-bg-opacity: 1;
background-color: #ffffff;
margin: auto;
border-radius:20px;
}

.bg-input {
background-color: #37363669;
border: 1px solid #ffffff5d;
border-radius: 20px;
box-shadow: 1.171px 9.607px 15px 0px rgba(164, 165, 166, 0);
}

.bg-\[\#414cb8\] {
--tw-bg-opacity: 1;
background-color: rgb(65 76 184/var(--tw-bg-opacity))
}

.bg-\[\#575e81\] {
--tw-bg-opacity: 1;
background-color: rgb(87 94 129/var(--tw-bg-opacity))
}

.bg-red-900 {
--tw-bg-opacity: 1;
background-color: rgb(127 29 29/var(--tw-bg-opacity))
}

.bg-red {
--tw-bg-opacity: 1;
background-color: #4800ff;
border-radius: 20px;
}

.bg-transparent {
background-color: initial
}

.bg-gradient-to-r {
background-image: linear-gradient(to right, var(--tw-gradient-stops))
}

.from-input {
background-color: #232429;
border-radius: 20px;
width: 100%;
}
.to-transparent {
--tw-gradient-to: #0000 var(--tw-gradient-to-position)
}

.stroke-\[\#FFFFFF\],
.stroke-white {
stroke: #000000;
}

.p-2 {
padding: .5rem
}

.px-1 {
padding-left: 1rem;
padding-right: 1rem;
}

.px-2 {
padding-left: .5rem;
padding-right: .5rem
}

.px-3 {
padding-left: .75rem;
padding-right: .75rem
}

.px-\[10\%\] {
padding-left: 10%;
padding-right: 10%
}

.px-\[10px\] {
padding-left: 10px;
padding-right: 10px
}

.py-2 {
padding-top: .5rem;
padding-bottom: .5rem
}

.py-2\.5 {
padding-top: 1.0rem;
padding-bottom: 1.1rem
}

.pb-\[30px\] {
padding-bottom: 30px
}

.pl-1 {
padding-left: 0.8rem;
}

.pr-6 {
padding-right: 1.5rem
}

.pt-\[10px\] {
padding-top: 10px
}

.text-center {
text-align: center
}

.text-\[0\.5rem\] {
font-size: .5rem
}

.text-\[0\.65rem\] {
font-size: .65rem
}

.text-\[0\.6rem\] {
font-size: .6rem
}

.text-lg {
font-size: 1.125rem;
line-height: 1;
}

.text-sm {
font-size: .775rem;
line-height: 1rem
}

.text-xs {
font-size: .75rem;
line-height: 1rem
}

.font-medium {
font-weight: 500
}

.leading-7 {
line-height: 1.75rem
}

.text-\[\#11c9ff\] {
--tw-text-opacity: 1;
color: rgb(17 201 255/var(--tw-text-opacity))
}

.text-\[\#767881\] {
--tw-text-opacity: 1;
color: rgb(118 120 129/var(--tw-text-opacity))
}

.text-\[\#7d7f81\] {
--tw-text-opacity: 1;
color: rgb(125 127 129/var(--tw-text-opacity))
}

.text-\[\#FF0000\] {
--tw-text-opacity: 1;
color: rgb(0 90 255)
}

.text-white {
--tw-text-opacity: 1;
color: rgb(255 255 255/var(--tw-text-opacity))
}

.text-black {
--tw-text-opacity: 1;
color: rgb(0 0 0/var(--tw-text-opacity))
}

.shadow-\[0px_0px_10px_0px_rgba\(18\2c 22\2c 34\2c 1\)\] {
--tw-shadow: 0px 0px 10px 0px #121622;
--tw-shadow-colored: 0px 0px 10px 0px var(--tw-shadow-color);
}

.outline-none {
outline: 2px solid #0000;
outline-offset: 2px
}

.transition-\[max-height\] {
transition-property: max-height;
transition-timing-function: cubic-bezier(.4, 0, .2, 1);
transition-duration: .15s
}

.transition-all {
transition-property: all;
transition-timing-function: cubic-bezier(.4, 0, .2, 1);
transition-duration: .15s
}

.duration-1000 {
transition-duration: 1s
}

@media (max-width:300px) {
.max-\[300px\]\:text-sm {
font-size: .775rem;
line-height: 1rem
}
}

@media (min-width:280px) {
.min-\[280px\]\:text-sm {
font-size: .875rem;
line-height: 1.25rem
}

.min-\[280px\]\:text-xs {
font-size: .75rem;
line-height: 1rem
}
}

.button-container {

display: flex;
}

.normal-button {
flex: 1;
background: #373737;
color: white;
border: none;
padding: 5px;
font-size: 14px;
margin-right: 10px;
margin-top: 10px;
border-radius: 20px;
}

.normal-button:last-child {
margin-right: 0;
}

.normal-button:hover {
background-color: #0400ff;
}

.w-payloads {
width: 92%;
}


.icon {
margin-right: 10px;
color: red;
}

@media (min-width: 768px) {
.w-11/12 {
width: 92%;
}
}

.w-9\/9 {
width: 40%;
margin-left: 5px;
margin-right: 5px;
}

.mt-13 {
margin-top: 15px;
}

#container-configs {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.8);
z-index: 9999;
transition: all 0.3s ease;
}

#container-configs > section {
width: 100%; 
max-height: 100%; 
overflow: auto;
background-color: white;
border-radius: 10px;
padding: 20px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.3);
}

#container-configs h1 {
font-size: 14px;
font-weight: bold;
}

#container-configs p {
font-size: 12px;
color: #555;
}

#area-carrier-list {
display: flex;
flex-direction: column;
}

#area-carrier-list label {
border: 1px solid #ccc;
border-radius: 5px;
padding: 10px;
cursor: pointer;
transition: background-color 0.3s ease;
}

#area-carrier-list label:hover {
background-color: #f0f0f0;
}

#area-carrier-list label img {
width: 40px;
height: 40px;
border-radius: 50%;
margin-right: 20px;
margin-l: 20px;
}

.loader {
max-width: 15rem;
width: 50%;
height: auto;
stroke-linecap: round;
margin: auto;
margin-top: -70px;
}

circle {
fill: none;
stroke-width: 3.5;
animation-name: preloader;
animation-duration: 3s;
animation-iteration-count: infinite;
animation-timing-function: ease-in-out;
transform-origin: 170px 170px;
will-change: transform;

&:nth-of-type(1) {
stroke-dasharray: 350px;
}

&:nth-of-type(2) {
stroke-dasharray: 300px;
}

&:nth-of-type(3) {
stroke-dasharray: 250px;
}

&:nth-of-type(4) {
stroke-dasharray: 100px;
}

@for $i from 1 through 4 {
&:nth-of-type(#{$i}) {
animation-delay: -#{$i * 0.15}s;
}
}
}
@keyframes preloader {
50% {
transform: rotate(360deg);
}
}

.connection-img {
width: 100%;
margin-top: -70px;
}

.help-bottom {
background: #000000;
border-radius: 20px; 
padding: 4px 15px 4px 15px; 
color: #ffffff; 
font-size: 13px;
}

p {
line-height: 1.2 !important;
}

.page-title {
    background: #121622;
    border: 1px solid #343a40;
    padding: 5px 15px 10px 15px;
    border-radius: 15px;
    margin-top: 10px;
    box-shadow: 1.171px 9.607px 15px 0px rgba(71, 95, 123, 0.2);
}
.title-default {
font-size: 17px;
font-weight: 700;
text-align: center;
}

.title-sessions {
font-size: 18px;
font-weight: 700;
text-align: center;
}

.text-default {
font-size: 15px;
text-align: center;
margin-bottom: 10px;
}

.text-default-black {
color: #000000;
font-weight: 700;
font-size: 15px;
text-align: center;
margin-bottom: 10px;
}

.svg-sessions {
width: 150px;
    margin: auto;
    margin-top: 20px;
}

.button-black {
background: #373737;
border-radius: 20px;
}


 .menu-btn {
            display: flex;
            align-items: center;
            margin-bottom: 10px !important;
            padding: 10px;
            border: 1px solid #ccc;
            cursor: pointer;
            transition: background-color 0.3s;
            max-width: 90%; /* Largura máxima de 90% */
            margin: 0 auto; /* Centralizar horizontalmente */
			border-radius: 20px;
        }

        .menu-btn:hover {
            background-color: #eee;
        }

        .icon-menu {
            margin-right: 10px;
			font-size: 40px;
        }

        .text-menu {
            display: flex;
            flex-direction: column;
        }

        .title-menu {
            font-weight: bold;
			line-height: 1.1;
        }

        .subtitle-menu {
            color: #000000;
			line-height: 1.1;
			font-size: 13px;
        }
		
		.menu-mobile {
            width: 100%;
            box-sizing: border-box;
		}

.bg-pop-up-menu {
    --tw-bg-opacity: 1;
    background-color: #ffffff;
    margin: auto;
    border-radius: 20px;
    height: auto;
	padding: 10px 0px 20px 0px;
}

.configButton {
    display: flex;
    align-items: center; /* Centraliza verticalmente */
    justify-content: center; /* Centraliza horizontalmente */
}



</style>
</head>

<body class="w-full h-full">
<main class="w-full h-full flex flex-col relative">
<section class="w-full h-full flex flex-col px-[10px] pt-[10px] pb-[30px] overflow-hidden" id="container-home">
<section class="flex justify-between items-center relative" style="margin-top: 10px;">
<svg xmlns="http://www.w3.org/2000/svg" id="open-menu" viewBox="0 0 24 24" width="20" height="20" fill="white"><path d="M7,0H4A4,4,0,0,0,0,4V7a4,4,0,0,0,4,4H7a4,4,0,0,0,4-4V4A4,4,0,0,0,7,0ZM9,7A2,2,0,0,1,7,9H4A2,2,0,0,1,2,7V4A2,2,0,0,1,4,2H7A2,2,0,0,1,9,4Z"/><path d="M20,0H17a4,4,0,0,0-4,4V7a4,4,0,0,0,4,4h3a4,4,0,0,0,4-4V4A4,4,0,0,0,20,0Zm2,7a2,2,0,0,1-2,2H17a2,2,0,0,1-2-2V4a2,2,0,0,1,2-2h3a2,2,0,0,1,2,2Z"/><path d="M7,13H4a4,4,0,0,0-4,4v3a4,4,0,0,0,4,4H7a4,4,0,0,0,4-4V17A4,4,0,0,0,7,13Zm2,7a2,2,0,0,1-2,2H4a2,2,0,0,1-2-2V17a2,2,0,0,1,2-2H7a2,2,0,0,1,2,2Z"/><path d="M20,13H17a4,4,0,0,0-4,4v3a4,4,0,0,0,4,4h3a4,4,0,0,0,4-4V17A4,4,0,0,0,20,13Zm2,7a2,2,0,0,1-2,2H17a2,2,0,0,1-2-2V17a2,2,0,0,1,2-2h3a2,2,0,0,1,2,2Z"/></svg>
<div class="absolute left-1/2 top-1/2 transform -translate-x-1/2 -translate-y-1/2">
<span class="text-white min-[280px]:text-sm text-sm title-default">CASS-TUNNEL</span>
</div>

<div>
<span class="help-bottom" id="nav-help">Ajuda</span>
</div>
</section>

<div class="page-title">
<div class="subtitle">

</div>
<div>
  <p style="text-align: center;">
    <span class="text-white text-sm mr-2">IP Local: </span>
    <span class="text-white text-sm mr-2" id="ipAddress">Sem sinal</span>
  </p>
  <p style="text-align: center;">
    <span class="text-white font-semibold text-sm mr-2">Versão: </span>
    <span class="text-white text-sm mr-2" id="version"></span>
  </p>
  <p style="text-align: center;">
       <span class="text-white text-sm mr-2" style="font-weight: 700;">Status: </span>
    <span class="text-[#767881] text-sm mr-4 font-medium w-3 h-6" id="state">Desconectado</span>
</p>
</div>

</div>

<section class="w-full h-1/5 flex justify-center" style="margin-top:10px;">
<img class="w-full" id="logoImg" style="border-radius: 20px;" src="" alt="logo" />
</section>


<section class="w-full h-auto flex flex-col items-center gap-3 mt-2.5 py-2.5 bg-input rounded-md">
<h1 class="text-[#7d7f81] text-lg font-medium" style="text-align:center;"></h1>

<section class="w-payloads h-[40px] flex justify-between items-center gap-2 text-white" id="xvideos">
<button class="w-[calc(100%-40px)] h-full flex items-center justify-between gap-1 px-1 rounded-md cursor-none outline-none bg-payloads configButton" id="openConfigModalButton" type="button" title="Selecionar Configuração">
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="w-6 h-6 text-white" viewBox="0 0 16 16">
<path d="M8 16s6-5.686 6-10A6 6 0 0 0 2 6c0 4.314 6 10 6 10m0-7a3 3 0 1 1 0-6 3 3 0 0 1 0 6" />
</svg>

<span class="w-full text-white text-xs truncate" id="value-of-carrier">ESCOLHA UMA CONFIGURAÇÃO</span>

<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="text- w-5 h-5" viewBox="0 0 16 16">
<path fill-rule="evenodd" d="M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z" />
</svg>
</button>
</section>





<div class="flex gap-2 items-center" style="width: 92%;">
<div class="w-1/2 h-9 overflow-hidden border border-[#01010342] rounded-md bg-gradient-to-r from-input to-transparent" id="container-input-username">
<input class="w-full h-full pl-1 outline-none text-white bg-transparent " id="username" type="text" placeholder="Usuário" />
</div>

<div class="w-1/2 h-9 flex items-center relative overflow-hidden border border-[#01010342] rounded-md bg-gradient-to-r from-input to-transparent" id="container-input-password">
<input class="w-full h-full pl-1 outline-none text-white bg-transparent" id="password" type="password" placeholder="Senha" />

<svg xmlns="http://www.w3.org/2000/svg"  width="16" height="16" fill="currentColor" class="w-5 h-5 absolute right-1 text-white" id="eye-view-password" viewBox="0 0 16 16">
<path d="M16 8s-3-5.5-8-5.5S0 8 0 8s3 5.5 8 5.5S16 8 16 8M1.173 8a13.133 13.133 0 0 1 1.66-2.043C4.12 4.668 5.88 3.5 8 3.5c2.12 0 3.879 1.168 5.168 2.457A13.133 13.133 0 0 1 14.828 8c-.058.087-.122.183-.195.288-.335.48-.83 1.12-1.465 1.755C11.879 11.332 10.119 12.5 8 12.5c-2.12 0-3.879-1.168-5.168-2.457A13.134 13.134 0 0 1 1.172 8z" />
<path d="M8 5.5a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5M4.5 8a3.5 3.5 0 1 1 7 0 3.5 3.5 0 0 1-7 0" />
</svg>

<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="w-5 h-5 absolute right-1 text-black hidden" id="eye-not-view-password" viewBox="0 0 16 16">
<path d="M13.359 11.238C15.06 9.72 16 8 16 8s-3-5.5-8-5.5a7.028 7.028 0 0 0-2.79.588l.77.771A5.944 5.944 0 0 1 8 3.5c2.12 0 3.879 1.168 5.168 2.457A13.134 13.134 0 0 1 14.828 8c-.058.087-.122.183-.195.288-.335.48-.83 1.12-1.465 1.755-.165.165-.337.328-.517.486z" />
<path d="M11.297 9.176a3.5 3.5 0 0 0-4.474-4.474l.823.823a2.5 2.5 0 0 1 2.829 2.829zm-2.943 1.299.822.822a3.5 3.5 0 0 1-4.474-4.474l.823.823a2.5 2.5 0 0 0 2.829 2.829" />
<path d="M3.35 5.47c-.18.16-.353.322-.518.487A13.134 13.134 0 0 0 1.172 8l.195.288c.335.48.83 1.12 1.465 1.755C4.121 11.332 5.881 12.5 8 12.5c.716 0 1.39-.133 2.02-.36l.77.772A7.029 7.029 0 0 1 8 13.5C3 13.5 0 8 0 8s.939-1.721 2.641-3.238l.708.709zm10.296 8.884-12-12 .708-.708 12 12-.708.708" />
</svg>
</div>
</div>

<div id="spinner" style="display: none; margin-top: 50px;">
  <svg class="loader" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 340 340">
    <circle cx="170" cy="170" r="160" stroke="#0074ba" />
    <circle cx="170" cy="170" r="135" stroke="#00d26a" />
    <circle cx="170" cy="170" r="110" stroke="#0074ba" />
    <circle cx="170" cy="170" r="85" stroke="#00d26a" />
  </svg>
  <p class="text-white text-center ">Conectando...</p>
</div>

<div class="connection-img " id="connected-img" style="display: none; margin-top: -10px;">
  <img style="width: 40% !important; margin: auto;"
    src="https://cdna.artstation.com/p/assets/images/images/050/392/912/original/nelson-tiapa-gif-con-telefono.gif" />
    <p class="text-white text-center ">Conectado com sucesso ✅
</div>

<button class="w-11/12 h-9 rounded-md shadow-[0px_0px_10px_0px_rgba(18,22,34,1)] bg-conect cursor-none" onclick="startOrStop();" id="startOrStopButton"  title="conectar ou desconectar vpn">
<span class="font-medium text-white" id="status-button-vpn" style="font-size: 15px;">Conectar</span>
</button>
</section>

<section class="button-container">
<button class="normal-button" id="sync" onclick="app.searchUpdate()">Atualizar</button>
<button class="normal-button" id="button-logs"><span class="icon-buttons">Registros</button>
<button class="normal-button" id="nav-perfil"><span class="icon-buttons">Perfil</button>
</section>





<section class="promo-section text-white" style="text-align: center; margin-top: 10px;">Mantenha seu aplicativo sempre atualizado e evite a interrupção dos serviços.
</section>

<!-- Adicionei um espaço aqui -->
<div style="height: 250px;"></div>

<section id="caixachecker" class="bg-input rounded-md user-info-container text-white" style="display: none; text-align: center; font-family: Georgia, 'Times New Roman', Times, serif;">

    <p>Olá: <span id="usernamee"></span></p>
    <p>Usuários conectados: <span id="countConnection"></span></p>
    <p>Validade: <span id="expirationDate"></span></p>
    <p>Dias restantes: <span id="expirationDays"></span></p>
    <p>Limite: <span id="limiterUser"></span></p>
</section>



<section class="w-full h-10 flex items-center justify-center gap-2 mt-auto rounded-md bg-buttons" id="nav-help" style="display: none;">
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="text-white w-4 h-4" viewBox="0 0 16 16">
<path d="M5.5 7a.5.5 0 0 0 0 1h5a.5.5 0 0 0 0-1zM5 9.5a.5.5 0 0 1 .5-.5h5a.5.5 0 0 1 0 1h-5a.5.5 0 0 1-.5-.5m0 2a.5.5 0 0 1 .5-.5h2a.5.5 0 0 1 0 1h-2a.5.5 0 0 1-.5-.5" />
<path d="M9.5 0H4a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2V4.5zm0 1v2A1.5 1.5 0 0 0 11 4.5h2V14a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V2a1 1 0 0 1 1-1z" />
</svg>

<span class="text-white text-sm font-medium">PRECISO DE AJUDA</span>
</section>
</section>

<section class="w-full h-full flex flex-col items-center absolute transition-all bg-black -translate-x-full" id="container-menu">
<section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up-menu">
<section class="w-full h-10 flex justify-between items-center px-1">
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="ml-auto text-black w-8 h-8" id="hidden-menu" viewBox="0 0 24 24">
<path d="M19,2H5C2.243,2,0,4.243,0,7v10c0,2.757,2.243,5,5,5h14c2.757,0,5-2.243,5-5V7c0-2.757-2.243-5-5-5Zm3,15c0,1.654-1.346,3-3,3H5c-1.654,0-3-1.346-3-3V7c0-1.654,1.346-3,3-3h14c1.654,0,3,1.346,3,3v10Zm-5.793-7.793l-2.793,2.793,2.793,2.793c.391,.391,.391,1.023,0,1.414-.195,.195-.451,.293-.707,.293s-.512-.098-.707-.293l-2.793-2.793-2.793,2.793c-.195,.195-.451,.293-.707,.293s-.512-.098-.707-.293c-.391-.391-.391-1.023,0-1.414l2.793-2.793-2.793-2.793c-.391-.391-.391-1.023,0-1.414s1.023-.391,1.414,0l2.793,2.793,2.793-2.793c.391-.391,1.023-.391,1.414,0s.391,1.023,0,1.414Z"/></svg>
</section>

<section class="menu-mobile">
   <div class="menu-btn" id="nav-terms">
        <div class="icon-menu">
            <!-- Substitua o conteúdo abaixo pelo seu SVG -->
            <svg xmlns="http://www.w3.org/2000/svg" width="40" height="40" viewBox="0 0 24 24"><path d="M22.775,9.792c-.778-.649-1.8-.917-2.795-.737l-5.897,1.072c-.795,.145-1.507,.499-2.083,1-.576-.501-1.288-.855-2.083-1l-5.898-1.073c-.997-.179-2.015,.087-2.794,.737-.778,.649-1.225,1.604-1.225,2.617v9.433l12,2.182,12-2.182V12.41c0-1.014-.446-1.967-1.225-2.617Zm-12.275,10.91l-7.5-1.364v-6.929c0-.167,.092-.268,.147-.314,.055-.046,.169-.117,.335-.089l5.898,1.072c.648,.118,1.12,.683,1.12,1.342v6.281Zm10.5-1.364l-7.5,1.364v-6.281c0-.66,.471-1.224,1.12-1.342l5.897-1.072c.166-.033,.28,.042,.335,.088,.056,.046,.147,.147,.147,.314v6.929ZM7.5,4.5C7.5,2.015,9.515,0,12,0s4.5,2.015,4.5,4.5-2.015,4.5-4.5,4.5-4.5-2.015-4.5-4.5Z"/></svg>
        </div>
        <div class="text-menu">
            <div class="title-menu">Termos de uso do aplicativo</div>
            <div class="subtitle-menu">Leia cuidadosamente nossos termos antes de usar o aplicativo.</div>
        </div>
    </div>
	</section>
	
	<section class="menu-mobile">
   <div class="menu-btn" id="nav-hotspot" onclick="app.openHostShare()" >
        <div class="icon-menu">
            <!-- Substitua o conteúdo abaixo pelo seu SVG -->
            <svg xmlns="http://www.w3.org/2000/svg" width="40" height="40" viewBox="0 0 24 24"><path d="m20,15h-4v-4c0-.552-.447-1-1-1s-1,.448-1,1v4H4c-2.206,0-4,1.794-4,4v1c0,2.206,1.794,4,4,4h16c2.206,0,4-1.794,4-4v-1c0-2.206-1.794-4-4-4Zm-15.5,6c-.828,0-1.5-.672-1.5-1.5s.672-1.5,1.5-1.5,1.5.672,1.5,1.5-.672,1.5-1.5,1.5Zm5,0c-.828,0-1.5-.672-1.5-1.5s.672-1.5,1.5-1.5,1.5.672,1.5,1.5-.672,1.5-1.5,1.5ZM15,5c1.817,0,3.526.708,4.812,1.993.391.391.391,1.024,0,1.414-.195.195-.451.293-.707.293s-.512-.098-.707-.293c-.907-.908-2.114-1.407-3.397-1.407s-2.49.5-3.397,1.407c-.39.391-1.023.391-1.414,0-.391-.39-.391-1.023,0-1.414,1.285-1.285,2.994-1.993,4.811-1.993Zm-8.778-1.182C8.485,1.392,11.684,0,15,0s6.516,1.392,8.778,3.818c.377.404.354,1.037-.05,1.414-.192.18-.438.269-.682.269-.268,0-.534-.107-.731-.318-1.886-2.022-4.552-3.182-7.315-3.182s-5.43,1.16-7.315,3.182c-.378.404-1.01.425-1.414.049-.404-.377-.426-1.01-.049-1.414Z"/>
</svg>
        </div>
        <div class="text-menu">
            <div class="title-menu">Roteador Wi-fi (Proxy)</div>
            <div class="subtitle-menu">Compartilhe sua internet com outras pessoas.</div>
        </div>
    </div>
	</section>
	
	<section class="menu-mobile">
   <div class="menu-btn" id="nav-apn">
        <div class="icon-menu">
            <!-- Substitua o conteúdo abaixo pelo seu SVG -->
            <svg xmlns="http://www.w3.org/2000/svg" width="40" height="40" viewBox="0 0 24 24"><path d="m17,0h-4.757c-1.068,0-2.072.416-2.829,1.172l-2.242,2.242c-.745.744-1.172,1.774-1.172,2.828v8.758c0,2.757,2.243,5,5,5h6c2.757,0,5-2.243,5-5V5c0-2.757-2.243-5-5-5Zm3,15c0,1.654-1.346,3-3,3h-6c-1.654,0-3-1.346-3-3V6.242c0-.526.213-1.042.586-1.414l2.242-2.242c.378-.378.881-.586,1.415-.586h4.757c1.654,0,3,1.346,3,3v10Zm-3,8c0,.553-.447,1-1,1h-5c-4.962,0-9-4.037-9-9v-7c0-.553.448-1,1-1s1,.447,1,1v7c0,3.859,3.14,7,7,7h5c.553,0,1,.447,1,1Zm-3-11h-4v-1.5c0-.828.672-1.5,1.5-1.5h2.5v3Zm4-1.5v1.5h-3v-3h1.5c.828,0,1.5.672,1.5,1.5Zm-8,2.5h3v3h-1.5c-.828,0-1.5-.672-1.5-1.5v-1.5Zm4,0h4v1.5c0,.828-.672,1.5-1.5,1.5h-2.5v-3Z"/>
</svg>
        </div>
        <div class="text-menu">
            <div class="title-menu">Configurações de APN</div>
            <div class="subtitle-menu">Ajuste seu chip para conseguir navegar corretamente.</div>
        </div>
    </div>
	</section>
	
	<section class="menu-mobile">
   <div class="menu-btn"  onclick="app.openWebview('https://app.ctunnel.online')" >
        <div class="icon-menu">
            <!-- Substitua o conteúdo abaixo pelo seu SVG -->
            <svg version="1.0" xmlns="http://www.w3.org/2000/svg"
 width="40" height="40" viewBox="0 0 512.000000 512.000000"
 preserveAspectRatio="xMidYMid meet">

<g transform="translate(0.000000,512.000000) scale(0.100000,-0.100000)"
fill="#000000" stroke="none">
<path d="M2380 5114 c-19 -2 -78 -9 -130 -14 -330 -36 -695 -160 -990 -336
-375 -224 -680 -529 -904 -904 -175 -292 -291 -632 -338 -990 -16 -123 -16
-497 0 -620 82 -623 356 -1150 820 -1581 256 -239 575 -425 922 -539 274 -91
491 -124 800 -124 228 0 329 9 530 50 689 141 1304 583 1674 1204 175 292 291
632 338 990 16 123 16 497 0 620 -47 358 -163 698 -338 990 -224 375 -529 680
-904 904 -289 173 -634 291 -980 336 -88 12 -438 21 -500 14z m27 -1340 c-8
-9 -760 40 -774 50 -7 5 84 221 136 324 165 330 384 562 600 637 l36 12 3
-510 c1 -281 1 -511 -1 -513z m424 976 c185 -93 376 -315 520 -602 62 -124
142 -319 134 -327 -8 -8 -419 -38 -602 -45 l-173 -6 0 515 0 514 38 -13 c22
-8 59 -24 83 -36z m-1107 -102 c-4 -7 -28 -42 -54 -78 -110 -151 -224 -375
-305 -597 -22 -60 -43 -103 -50 -103 -43 0 -490 102 -502 114 -8 7 98 126 189
212 168 160 349 285 563 390 154 76 171 83 159 62z m1831 -62 c214 -105 393
-229 564 -391 95 -90 204 -216 194 -226 -17 -15 -509 -118 -517 -108 -1 2 -20
51 -41 109 -80 222 -194 447 -305 600 -57 79 -64 90 -53 90 5 0 76 -33 158
-74z m-2838 -890 c95 -29 358 -90 457 -107 l68 -11 -5 -37 c-3 -20 -17 -97
-30 -171 -31 -163 -54 -361 -63 -532 l-7 -128 -414 0 -413 0 0 36 c0 113 57
385 117 558 50 147 181 416 202 416 4 0 44 -11 88 -24z m3878 -158 c72 -150
121 -286 159 -439 27 -112 56 -294 56 -353 l0 -36 -413 0 -414 0 -7 128 c-9
171 -32 368 -62 532 -14 74 -28 149 -31 166 l-5 32 73 12 c99 16 363 74 469
104 101 28 84 42 175 -146z m-2893 -23 c123 -13 294 -25 591 -41 l117 -6 0
-379 0 -379 -485 0 -485 0 0 53 c0 205 85 767 116 767 7 0 72 -7 146 -15z
m1878 1 c0 -2 9 -47 20 -99 41 -201 80 -519 80 -654 l0 -53 -485 0 -485 0 0
379 0 378 163 7 c192 8 600 36 606 42 6 5 101 5 101 0z m-2432 -1279 c13 -189
41 -398 73 -550 23 -105 21 -127 -11 -127 -36 0 -365 -70 -474 -100 -59 -17
-113 -30 -122 -30 -22 0 -143 253 -192 402 -61 184 -112 430 -112 542 l0 36
413 0 413 0 12 -173z m1262 -202 l0 -375 -117 0 c-144 0 -397 -15 -597 -35
-82 -9 -150 -14 -151 -13 -2 2 -15 60 -29 130 -31 153 -62 390 -72 551 l-7
117 487 0 486 0 0 -375z m1266 258 c-10 -161 -41 -402 -72 -553 -14 -69 -28
-128 -29 -131 -2 -3 -35 -2 -72 3 -158 19 -421 38 -600 45 l-193 6 0 374 0
373 486 0 487 0 -7 -117z m1134 81 c0 -113 -51 -358 -112 -544 -53 -159 -183
-424 -204 -416 -71 27 -574 146 -618 146 -2 0 5 39 15 88 32 144 68 404 81
588 l12 174 413 0 413 0 0 -36z m-2400 -1524 c0 -280 -2 -510 -4 -510 -9 0
-85 33 -131 57 -182 96 -376 324 -511 601 -51 106 -137 313 -131 318 3 2 381
33 462 37 33 2 117 4 188 5 l127 2 0 -510z m835 485 c88 -8 179 -17 202 -20
l41 -6 -38 -98 c-153 -393 -377 -694 -605 -814 -46 -24 -122 -57 -131 -57 -2
0 -4 230 -4 511 l0 512 188 -7 c103 -4 259 -14 347 -21z m-1899 -118 c83 -251
209 -490 393 -748 14 -20 13 -20 -37 0 -233 92 -500 266 -702 458 -91 87 -217
230 -209 237 16 13 517 116 531 109 3 -2 14 -27 24 -56z m2574 28 c119 -23
383 -86 393 -94 11 -10 -103 -140 -208 -238 -195 -183 -461 -355 -687 -444
-50 -20 -51 -20 -37 0 184 258 310 497 393 748 15 46 21 52 39 48 12 -2 60
-11 107 -20z"/>
</g>
</svg>
        </div>
        <div class="text-menu" >
            <div class="title-menu">Pagina Web</div>
            <div class="subtitle-menu">Informações Adicionais</div>
        </div>
    </div>
	</section>
	
	
	<section class="menu-mobile"  onclick="app.offlineUpdate()" >
   <div class="menu-btn" >
        <div class="icon-menu">
            <svg version="1.0" xmlns="http://www.w3.org/2000/svg"
 width="40" height="40" viewBox="0 0 512.000000 512.000000"
 preserveAspectRatio="xMidYMid meet">

<g transform="translate(0.000000,512.000000) scale(0.100000,-0.100000)"
fill="#000000" stroke="none">
<path d="M1055 5110 c-194 -41 -352 -179 -417 -368 l-23 -67 0 -2115 0 -2115
23 -66 c57 -166 185 -294 350 -351 l67 -23 1505 0 1505 0 67 23 c165 57 293
185 350 351 l23 66 0 1660 0 1660 -26 71 c-14 39 -43 96 -63 127 -46 69 -1028
1002 -1119 1064 -34 22 -91 52 -127 65 l-65 23 -1005 2 c-553 0 -1023 -3
-1045 -7z m1897 -758 l3 -467 33 -67 c38 -77 92 -130 171 -167 l56 -26 498 -3
497 -3 0 -1553 c0 -1744 6 -1611 -75 -1691 -80 -81 39 -75 -1575 -75 -1614 0
-1495 -6 -1575 75 -82 81 -75 -112 -75 2185 0 2298 -7 2104 75 2185 77 77 20
73 1047 74 l917 1 3 -468z m761 -116 c180 -170 327 -311 327 -313 0 -1 -171
-3 -379 -3 -332 0 -382 2 -395 16 -14 13 -16 62 -16 376 l0 360 68 -63 c37
-34 214 -202 395 -373z"/>
<path d="M1358 3099 c-43 -22 -78 -81 -78 -129 0 -50 35 -107 80 -130 39 -20
56 -20 1170 -20 1114 0 1131 0 1170 20 45 23 80 80 80 130 0 50 -35 107 -80
130 -39 20 -56 20 -1172 20 -1108 -1 -1134 -1 -1170 -21z"/>
<path d="M1358 2299 c-43 -22 -78 -81 -78 -129 0 -50 35 -107 80 -130 39 -20
56 -20 1170 -20 1114 0 1131 0 1170 20 45 23 80 80 80 130 0 50 -35 107 -80
130 -39 20 -56 20 -1172 20 -1108 -1 -1134 -1 -1170 -21z"/>
<path d="M1358 1500 c-43 -23 -78 -82 -78 -130 0 -50 35 -107 80 -130 39 -20
54 -21 445 -18 390 3 405 4 431 24 50 37 68 70 68 124 0 54 -18 87 -68 124
-27 20 -41 21 -434 23 -390 2 -409 2 -444 -17z"/>
</g>
</svg>  </div>
        <div class="text-menu">
            <div class="title-menu">Atualizar Offline</div>
            <div class="subtitle-menu">Atualizar sem necessidade de internet</div>
        </div>
    </div>
	</section>


    <section class="menu-mobile" style="margin-bottom:30px;" onclick="app.restartApp()">
   <div class="menu-btn" >
        <div class="icon-menu">
            <svg xmlns="http://www.w3.org/2000/svg" version="1.0" width="45" height="45" viewBox="0 0 512.000000 512.000000" preserveAspectRatio="xMidYMid meet">

<g transform="translate(0.000000,512.000000) scale(0.100000,-0.100000)" fill="#000000" stroke="none">
<path d="M2380 4714 c-430 -39 -826 -191 -1170 -448 -123 -91 -346 -315 -437 -436 -314 -423 -470 -921 -449 -1435 23 -578 246 -1086 656 -1495 352 -352 749 -553 1255 -636 153 -25 495 -26 650 -1 510 83 943 307 1289 668 326 340 525 743 603 1224 26 165 24 506 -5 675 -65 383 -197 692 -426 1000 -91 122 -314 346 -436 437 -303 226 -646 371 -1015 428 -97 15 -425 27 -515 19z m370 -324 c228 -24 436 -83 640 -181 869 -419 1293 -1413 994 -2329 -46 -140 -157 -362 -242 -485 -452 -652 -1238 -959 -2009 -786 -380 86 -755 309 -1014 604 -759 866 -594 2190 356 2849 119 83 344 195 474 238 259 85 543 117 801 90z"/>
<path d="M2420 3754 c-208 -27 -407 -101 -580 -217 -96 -64 -273 -241 -337 -337 -112 -167 -181 -349 -209 -547 l-17 -121 -21 30 c-37 55 -71 73 -136 73 -90 0 -149 -53 -157 -142 -5 -46 3 -63 170 -399 126 -253 184 -358 206 -377 57 -48 145 -48 202 0 22 19 80 124 206 377 167 336 175 353 170 399 -8 89 -67 142 -157 142 -66 0 -99 -18 -137 -75 -27 -39 -28 -30 -8 83 65 372 337 666 714 769 62 17 105 21 231 21 171 0 241 -13 381 -73 221 -94 418 -296 508 -521 53 -132 65 -199 65 -359 0 -160 -12 -227 -65 -359 -47 -117 -114 -217 -213 -317 -177 -176 -369 -262 -632 -283 -112 -8 -136 -19 -178 -75 -29 -39 -29 -133 0 -172 46 -62 66 -69 187 -68 227 2 458 77 667 217 96 64 273 241 337 337 95 142 163 302 199 470 26 119 26 381 0 500 -57 262 -167 464 -360 655 -185 184 -374 289 -626 346 -83 19 -331 33 -410 23z"/>
</g>
</svg>  </div>
        <div class="text-menu">
            <div class="title-menu">Reiniciar Aplicativo</div>
            <div class="subtitle-menu">Reiniciar aplicativo</div>
        </div>
    </div>
	</section>
</section>
</section>

<section class="w-full h-full flex flex-col items-center justify-center absolute transition-all scale-0 bg-black" id="container-terms">
<section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up">
<svg xmlns="http://www.w3.org/2000/svg" class="svg-sessions" id="termos" data-name="termos" viewBox="0 0 24 24">
<path d="M22.775,9.792c-.778-.649-1.8-.917-2.795-.737l-5.897,1.072c-.795,.145-1.507,.499-2.083,1-.576-.501-1.288-.855-2.083-1l-5.898-1.073c-.997-.179-2.015,.087-2.794,.737-.778,.649-1.225,1.604-1.225,2.617v9.433l12,2.182,12-2.182V12.41c0-1.014-.446-1.967-1.225-2.617Zm-12.275,10.91l-7.5-1.364v-6.929c0-.167,.092-.268,.147-.314,.055-.046,.169-.117,.335-.089l5.898,1.072c.648,.118,1.12,.683,1.12,1.342v6.281Zm10.5-1.364l-7.5,1.364v-6.281c0-.66,.471-1.224,1.12-1.342l5.897-1.072c.166-.033,.28,.042,.335,.088,.056,.046,.147,.147,.147,.314v6.929ZM7.5,4.5C7.5,2.015,9.515,0,12,0s4.5,2.015,4.5,4.5-2.015,4.5-4.5,4.5-4.5-2.015-4.5-4.5Z"/></svg>
<h1 class="w-full mt-13 text-[#FF0000] title-sessions">Termos de uso do aplicativo</h1>
<section class="w-full h-full mt-3 mb-3 px-3 overflow-auto text-center">
<p class="text-black text-default">1º - Suporte é direcionado apenas para (Clientes e revendedores) que estejam com todos os requisitos necessários para utilização do nosso aplicativo.</p>

<p class="text-black text-default">2º - Não assumimos responsabilidade pela abrangência do sinal das operadoras, tampouco por eventuais bloqueios ou interrupções de conexão, quer sejam atribuíveis a problemas técnicos da rede ou condições climáticas.</p>

<p class="text-black text-default">3º - A conectividade à internet pode ser restrita para determinados sites que implementam bloqueios ao uso de redes privadas virtuais (VPNs), tais como Bet365, Spotify, entre outros...</p>

<p class="text-black text-default">4º - O uso de programas como uTorrent ou aplicativos P2P, que podem resultar em danos aos nossos servidores, é extremamente proibido. O descumprimento dessa norma pode acarretar em banimento permanente, sem a possibilidade de reembolso.</p>

<p class="text-black text-default">5º - O cliente tem o direito de requerer o reembolso no período de até 7 dias corridos a partir da data de assinatura do plano. Em caso de aprovação do reembolso, o valor correspondente será estornado ao solicitante no prazo máximo de 15 dias.</p>
</section>
<section class="w-full h-auto flex items-center justify-center my-3">
<button class="w-2/4 h-9 rounded-md cursor-none button-black" id="close-terms-container" type="button">
<span class="text-white">CONCORDO</span>
</button>
</section>
</section>
</section>

<section class="w-full h-full flex flex-col items-center justify-center absolute transition-all scale-0 bg-black" id="container-help">
<section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up">
<svg xmlns="http://www.w3.org/2000/svg" class="svg-sessions" id="central-de-ajuda" data-name="central-de-ajuda" viewBox="0 0 24 24">
<path d="m22,9v-3c0-1.654-1.346-3-3-3h-6V0h-2v3h-6c-1.654,0-3,1.346-3,3v3H0v6h2v6h12.697l3.963,2.642c.36.24.775.361,1.191.361.348,0,.696-.084,1.015-.255.699-.375,1.134-1.1,1.134-1.894v-6.855h2v-6h-2Zm-2,12.855c0,.022,0,.089-.078.13-.08.043-.136.004-.152-.007l-4.467-2.978H4V6c0-.551.448-1,1-1h14c.552,0,1,.449,1,1v15.855ZM7,9.5c0-.828.672-1.5,1.5-1.5s1.5.672,1.5,1.5-.672,1.5-1.5,1.5-1.5-.672-1.5-1.5Zm7,0c0-.828.672-1.5,1.5-1.5s1.5.672,1.5,1.5-.672,1.5-1.5,1.5-1.5-.672-1.5-1.5Zm2.336,3.752l1.33,1.493c-.103.092-2.559,2.254-5.666,2.254s-5.563-2.162-5.666-2.254l1.33-1.493c.02.018,2.005,1.748,4.336,1.748s4.316-1.73,4.336-1.748Z"/>
</svg>
<h1 class="w-full mt-13 text-[#FF0000] title-sessions">Central de ajuda</h1>
<section class="w-full h-full mt-3 mb-3 px-3 overflow-auto text-center">
<p class="text-black text-default-black">Estou conectado, mas o aplicativo não está funcionando a internet, o que fazer?</p>

<p class="text-black text-default">Geralmente esse problema está relacionado ao protolo de APN, caso o IP da sua operadora seja: 192.0.0.2 ou 192.0.0.4 é necessário alterar o protolo de APN, você pode fazer isso clicando no menu e em seguida > Configurações de APN.</p>

<p class="text-black text-default-black">Se eu usar a (VPN) em meu dispositivo, isso irá consumir os dados da minha franquia fornecida pela operadora de celular?</p>

<p class="text-black text-default">Sim, o uso da VPN irá consumir a sua franquia de dados. Quando se tem uma franquia de dados, o aplicativo faz uma conexão direta, e passa a funcionar somente como um protetor de dados e localização;</p>

<p class="text-black text-default-black">Fiz um plano e agora quero saber se é possível rotear a internet?</p>

<p class="text-black text-default">Sim, é possível rotear através do roteamento via proxy, você pode fazer isso clicando no Menu e em seguida > Roteamento via proxy, vale ressaltar que o processo é complexo e por isso não damos assistência ao roteamento.</p>
</section>
<section class="w-full h-auto flex items-center justify-center my-3">
<button class="w-2/4 h-9 rounded-md cursor-none button-black" id="close-help-container" type="button">
<span class="text-white">Fechar</span>
</button>
</section>
</section>
</section>

<section class="w-full h-full flex flex-col items-center justify-center absolute transition-all scale-0 bg-black" id="container-perfil">
<section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up">
<svg xmlns="http://www.w3.org/2000/svg" class="svg-sessions" id="Minha-Conta" data-name="Minha-Conta" viewBox="0 0 24 24">
<path d="m18,12c-3.314,0-6,2.686-6,6s2.686,6,6,6,6-2.686,6-6-2.686-6-6-6Zm0,2c1.105,0,2,.895,2,2s-.895,2-2,2-2-.895-2-2,.895-2,2-2Zm3,6.64s-.007.011-.011.015c-.68.766-1.652,1.273-2.753,1.338-1.282.076-2.449-.476-3.236-1.375v-.119c0-.828.672-1.5,1.5-1.5h3c.828,0,1.5.672,1.5,1.5v.14Zm3-13.14v2.5c0,.828-.672,1.5-1.5,1.5s-1.5-.672-1.5-1.5H3v8.5c0,1.381,1.119,2.5,2.5,2.5h4c.828,0,1.5.672,1.5,1.5s-.672,1.5-1.5,1.5h-4c-3.038,0-5.5-2.462-5.5-5.5V7.5C0,4.462,2.462,2,5.5,2h.5v-.5c0-.828.672-1.5,1.5-1.5s1.5.672,1.5,1.5v.5h6v-.493c0-.833.675-1.507,1.507-1.507h.038c.804,0,1.455.652,1.455,1.455v.545s.5,0,.5,0c3.038,0,5.5,2.462,5.5,5.5Z"/>
</svg>
<h1 class="w-full mt-13 text-[#FF0000] title-sessions">Minha conta</h1>
<section class="w-full h-full mt-3 mb-3 px-3 overflow-auto text-center">
<p class="text-black text-default">Aqui está algumas informações básicas sobre o seu plano.</p>
<p class="text-black text-default">O seu nome de usuário é 
<span class="text-black text-default-black" id="usernames">Conecte para obter os dados)</span>,o seu plano irá vencer no dia 
<span class="text-black text-default-black" id="expirationDatee">conecte para verificar a validade</span>, você ainda tem 
<span class="text-black text-default-black" id="expirationDayss">Conecte para obter os dados)</span> dias do seu plano ilimitado.</p>
<p class="text-black text-default">Fique atento a validade do seu plano e renove sempre antes de vencer para evitar a interrupção do serviço.</p>
<p class="text-black text-default">Você pode renovar o seu plano de forma automática clicando no link abaixo.</p>
</section>
<section class="w-full h-auto flex items-center justify-center my-3">
    <button class="w-9/9 h-9 rounded-md cursor-none button-black" onclick="app.openWebView()"/div>
        <span class="text-white">Renovar</span>
</button>
<button class="w-9/9 h-9 rounded-md cursor-none bg-red" id="close-perfil-container" type="button">
<span class="text-white">Fechar</span>
</button>
</section>
</section>
</section>

<section class="w-full h-full flex flex-col items-center justify-center absolute transition-all scale-0 bg-black" id="container-logs">
  <section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up">

    <h1 class="w-full mt-13 text-[#FF0000] title-sessions">Logs</h1>
    <section class="w-full h-full mt-3 mb-3 px-3 overflow-auto text-center">
      <ul id="logList"></ul>
    </section>
    <section class="w-full h-auto flex items-center justify-center my-3">
      <button class="w-9/9 h-9 rounded-md cursor-none bg-red" id="close-logs-container" type="button" onclick="app.clearLogs()">
              <span class="text-white">Limpar Logs</span>
                    </button>
      <button class="w-9/9 h-9 rounded-md cursor-none bg-red" id="close-logs-container" type="button" onclick="hiddenContainerLogs()">
        <span class="text-white">Fechar</span>
      </button>
    </section>
  </section>
</section>

<section class="w-full h-full flex flex-col items-center justify-center absolute transition-all scale-0 bg-black" id="container-servers">
  <section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up">
    <h1 class="w-full mt-13 text-[##00FF00] title-sessions">Configurações</h1>
    <div class="w-full flex-1 px-2 py-4 overflow-y-auto" id="serverOptions">
    </div>
  </section>
</section>


<section class="w-full h-full flex flex-col items-center justify-center absolute transition-all scale-0 bg-black" id="container-apn">
<section class="w-11/12 h-2/3 flex flex-col relative rounded-md bg-pop-up">
<svg xmlns="http://www.w3.org/2000/svg" class="svg-sessions" id="alterando-apn" data-name="alterando-apn" viewBox="0 0 24 24">
<path d="m17,0h-4.757c-1.068,0-2.072.416-2.829,1.172l-2.242,2.242c-.745.744-1.172,1.774-1.172,2.828v8.758c0,2.757,2.243,5,5,5h6c2.757,0,5-2.243,5-5V5c0-2.757-2.243-5-5-5Zm3,15c0,1.654-1.346,3-3,3h-6c-1.654,0-3-1.346-3-3V6.242c0-.526.213-1.042.586-1.414l2.242-2.242c.378-.378.881-.586,1.415-.586h4.757c1.654,0,3,1.346,3,3v10Zm-3,8c0,.553-.447,1-1,1h-5c-4.962,0-9-4.037-9-9v-7c0-.553.448-1,1-1s1,.447,1,1v7c0,3.859,3.14,7,7,7h5c.553,0,1,.447,1,1Zm-3-11h-4v-1.5c0-.828.672-1.5,1.5-1.5h2.5v3Zm4-1.5v1.5h-3v-3h1.5c.828,0,1.5.672,1.5,1.5Zm-8,2.5h3v3h-1.5c-.828,0-1.5-.672-1.5-1.5v-1.5Zm4,0h4v1.5c0,.828-.672,1.5-1.5,1.5h-2.5v-3Z"/>
</svg>
<h1 class="w-full mt-13 text-[#FF0000] title-sessions">Alterando sua APN</h1>
<section class="w-full h-full mt-3 mb-3 px-3 overflow-auto text-center">
<p class="text-black text-default">O seu aplicativo não está conectando ou conecta e não gera dados? Faça o passo a passo a seguir e solucione seu problema.</p>
<p class="text-black text-default">1º - Selecione a opção de APN ao qual ja está marcada e deslize a tela até encontrar as opções, Protocolo APN e Protocolo de roaming APN.</p>
<p class="text-black text-default">2º - Após encontrar as opções realize o seguinte passo.</p>
<p class="text-black text-default">3º - No campo Protocolo APN, marque IPV4.</p>
<p class="text-black text-default">4º - No campo Protocolo de roaming APN, marque IPV4.</p>
<p class="text-black text-default">5º - Após selecionado os protolos IPV4, vá até os simbolo de opções no canto direito na parte superior da sua tela (ou na parte inferior do aparelho dependendo da sua versão do android) e clique em Salvar.</p>
<p class="text-black text-default">6º - Após salvar, volte para tela inicial do aplicativo e ligue o modo avião por 5 segundos.</p>
<p class="text-black text-default">Pronto, caso o problema for apenas de não gerar dados, você conseguirá conectar normalmente e usar nosso aplicativo.</p>
</section>
<section class="w-full h-auto flex items-center justify-center my-3">
<button class="w-9/9 h-9 rounded-md text-white cursor-none button-black" onclick="app.openApn()" type="button">
Alterar APN<span class="text-white"></span>
</button>
<button class="w-9/9 h-9 rounded-md cursor-none bg-red" id="close-apn-container" type="button">
<span class="text-white">Fechar</span>
</button>
</section>
</section>
</section>
</section>
</main>
<style>


.category-container {
    margin-bottom: 20px; 
}
</style>

<!-- DOM WRAPPER -->
<script>
const Dom = (selector) => {
const _elements = document.querySelectorAll(selector);

const wrapper = {
on(listeners) {
for (const [event, listener] of Object.entries(listeners)) {
_elements.forEach((element) => {
element.addEventListener(event, listener);
});
}

return wrapper;
},
addClass: (...tokens) => {
_elements.forEach((element) => {
element.classList.add(...tokens);
});

return wrapper;
},
removeClass: (...tokens) => {
_elements.forEach((element) => {
element.classList.remove(...tokens);
});

return wrapper;
},
toggleClass: (token, force) => {
_elements.forEach((element) => {
element.classList.toggle(token, force);
});

return wrapper;
},
style(styles) {
for (const [property, value] of Object.entries(styles)) {
_elements.forEach((element) => {
element.style[property] = value;
});
}

return wrapper;
},
attr(attrs) {
for (const [name, value] of Object.entries(attrs)) {
_elements.forEach((element) => element.setAttribute(name, value));
}

return wrapper;
},
html(value) {
_elements.forEach((element) => (element.innerHTML = value));
return wrapper;
},
/**
* @return {Element|null}
*/
element() {
return _elements.length > 0 ? _elements[0] : null;
},
allElements: _elements,
};

return wrapper;
};
</script>

<!-- VÁRIAVIES -->
<script>


const containerHome = Dom("#container-home");

const openMenuButton = Dom("#open-menu");


const containerInputUsername = Dom("#container-input-username");
const containerInputPassword = Dom("#container-input-password");
const inputUsername = Dom("#username");
const inputPassword = Dom("#password");
const eyeViewPasswordInput = Dom("#eye-view-password");
const eyeNotViewPasswordInput = Dom("#eye-not-view-password");
const buttonLogs = Dom("#button-logs");
const containerMenu = Dom("#container-menu");
const hiddenContainerMenuButton = Dom("#hidden-menu");
const expiresDateUserInMenu = Dom("#expires-date-user-in-menu");
const navTerms = Dom("#nav-terms");
const navPerfil = Dom("#nav-perfil");
const navHelp = Dom("#nav-help");
const navAPN = Dom("#nav-apn");
const containerTerms = Dom("#container-terms");
const closeContainerTerms = Dom("#close-terms-container");
const containerPerfil = Dom("#container-perfil");
const closeContainerPerfil = Dom("#close-perfil-container");
const containerHelp = Dom("#container-help");
const closeContainerHelp = Dom("#close-help-container");
const containerAPN = Dom("#container-apn");
const closeContainerAPN = Dom("#close-apn-container");
const inputsPeer = Dom("input.peer");
const labelsFor = Dom("label[for]");

</script>
<!-- FUNÇÕES -->
<script>


function showContainerLogs() {
  var containerLogs = document.getElementById("container-logs");
  containerLogs.classList.remove("scale-0");
}

function hiddenContainerLogs() {
  var containerLogs = document.getElementById("container-logs");
  containerLogs.classList.add("scale-0");
}


function showInputPasswordValue() {
eyeViewPasswordInput.addClass("hidden");
eyeNotViewPasswordInput.removeClass("hidden");
inputPassword.attr({ type: "text" });
}
function hiddenInputPasswordValue() {
eyeViewPasswordInput.removeClass("hidden");
eyeNotViewPasswordInput.addClass("hidden");
inputPassword.attr({ type: "password" });
}


function showContainerMenu() {
containerMenu.removeClass("-translate-x-full");

return;
}
function hiddenContainerMenu() {
containerMenu.addClass("-translate-x-full");

return;
}

function showContainerTerms() {
containerTerms.removeClass("scale-0");

return;
}
function hiddenContainerTerms() {
containerTerms.addClass("scale-0");

return;
}

function showContainerPerfil() {
containerPerfil.removeClass("scale-0");

return;
}
function hiddenContainerPerfil() {
containerPerfil.addClass("scale-0");

return;
}

function showContainerHelp() {
containerHelp.removeClass("scale-0");

return;
}
function hiddenContainerHelp() {
containerHelp.addClass("scale-0");

return;
}


function showContainerAPN() {
containerAPN.removeClass("scale-0");

return;
}
function hiddenContainerAPN() {
containerAPN.addClass("scale-0");

return;
}


function getExpirationDateOfUser() {
expiresDateUserInMenu.style({ display: "none" });
}


function toggleLabelHeight(inputId) {
const input = document.getElementById(inputId);
const label = document.querySelector(`label[for="${inputId}"]`);

if (input.checked) {
label.style.maxHeight = label.scrollHeight + "px";
} else {
label.style.maxHeight = "32px";
}
}

</script>

<!-- AÇÕES -->
<script>

containerHome.style({
padding: `${10}px 10px ${10}px 10px`,
});


eyeViewPasswordInput.on({ click: () => showInputPasswordValue() });
eyeNotViewPasswordInput.on({ click: () => hiddenInputPasswordValue() });



buttonLogs.on({ click: () => showContainerLogs() });

containerMenu.style({
padding: `${10}px 10px ${10}px 10px`,
});

openMenuButton.on({ click: () => showContainerMenu() });

hiddenContainerMenuButton.on({ click: () => hiddenContainerMenu() });

expiresDateUserInMenu.html(getExpirationDateOfUser());


navTerms.on({ click: () => showContainerTerms() });
closeContainerTerms.on({ click: () => hiddenContainerTerms() });

navPerfil.on({ click: () => showContainerPerfil() });
closeContainerPerfil.on({ click: () => hiddenContainerPerfil() });

navHelp.on({ click: () => showContainerHelp() });
closeContainerHelp.on({ click: () => hiddenContainerHelp() });


navAPN.on({ click: () => showContainerAPN() });
closeContainerAPN.on({ click: () => hiddenContainerAPN() });

function loadLogs() {
  var logList = document.getElementById("logList");
  var logs = JSON.parse(app.getlogs())

  var formattedLogs = '';
  logs.forEach(item => {
    formattedLogs += '<li class="list-group-item bg-transparent p-0 border-0 text-start ms-2 text-wrap" style="font-size: 12px; color: var(--text-color);">';
    formattedLogs += item.TIME;
    formattedLogs += '</li>';
  });

  logList.innerHTML = '<ul class="list-group">' + formattedLogs + '</ul>';
}

var previousLogs = [];

function checkAndLoadLogs() {
  var logs = JSON.parse(app.getlogs());

  if (!arraysAreEqual(logs, previousLogs)) {
    previousLogs = logs;
    loadLogs();
  }
}

function arraysAreEqual(arr1, arr2) {
  if (arr1.length !== arr2.length) {
    return false;
  }

  for (var i = 0; i < arr1.length; i++) {
    if (arr1[i].TIME !== arr2[i].TIME) {
      return false;
    }
  }

  return true;
}

function startOrStop() {
  const user = document.getElementById('username');
  const pass = document.getElementById('password');
  if (user.value != "" && pass.value != "") {
    localStorage.setItem('usuario', user.value);
    localStorage.setItem('senha', pass.value);
    app.setUserAndPass(user.value, pass.value);
  }

  app.startOrStop();
}

checkAndLoadLogs();

function mostrarEnderecoIP() {
  var ipAddress = window.app.getiplocal() + " Operadora: " + app.getOperadoraEmUso();
  document.getElementById("ipAddress").textContent = ipAddress;
}


setInterval(mostrarEnderecoIP, 1000);
window.onload = mostrarEnderecoIP;

document.getElementById("version").innerText = app.getVersion();

const state = document.getElementById("state");
const statusButton = document.getElementById("status-button-vpn");
const user = document.getElementById("username");
const pass = document.getElementById("password");

user.addEventListener("click", checkState);
pass.addEventListener("click", checkState);

function changeDisplay(spinnerDisplay, connectedDisplay, xvideosDisplay, usernameDisplay, passwordDisplay) {
  document.getElementById("spinner").style.display = spinnerDisplay;
  document.getElementById("connected-img").style.display = connectedDisplay;
  document.getElementById("xvideos").style.display = xvideosDisplay;
  document.getElementById("container-input-username").style.display = usernameDisplay;
  document.getElementById("container-input-password").style.display = passwordDisplay;
}

function showSpinner() {
  changeDisplay("block", "none", "none", "none", "none");
}

function showConnected() {
  changeDisplay("none", "block", "none", "none", "none");
}

function showDisconnected() {
  changeDisplay("none", "none", "block", "block", "block");
}

function updateState() {
  var currentState = app.getState();

  checkAndLoadLogs();
  if (currentState.toUpperCase() === "CONECTADO") {
    state.innerHTML = "<span style='color: green;'> Conectado</span>";
    statusButton.innerHTML = "Desconectar";
    statusButton.title = "Desconectar VPN";
    user.disabled = true;
    pass.disabled = true;
    startCheckuser()
 
    showConnected();
  } else if (
    currentState.toUpperCase() === "INICIANDO" ||
    currentState.toUpperCase() === "AUTENTICANDO" ||
    currentState.toUpperCase() === "CONECTANDO"
  ) {
    state.innerHTML = "<span style='color: orange;'> " + capitalizeFirstLetter(currentState.toLowerCase()) + "</span>";
    statusButton.innerHTML = "Conectando...";
    statusButton.title = "Conectar ou Desconectar VPN";
    user.disabled = true;
    pass.disabled = true;

    showSpinner();
  } else if (currentState.toUpperCase() === "RECONECTANDO" || currentState.toUpperCase() === "DESCONECTADO") {
    state.innerHTML = `<span style='color: ${currentState.toLowerCase() === "reconectando" ? "orange" : "red"};'>  ${capitalizeFirstLetter(currentState.toLowerCase())}</span>`;
    statusButton.innerHTML = "Conectar";
    statusButton.title = "Conectar VPN";
    user.disabled = false;
    pass.disabled = false;

    const userInfo = document.getElementById('caixachecker');
    userInfo.style.display = "none";
    showDisconnected();
  } else {
    state.innerHTML = "<span style='color: orange;'> Conectar</span>";
    statusButton.innerHTML = "Conectar";
    statusButton.title = "Conectar VPN";
    user.disabled = false;
    pass.disabled = false;

    showDisconnected();
  }

  previousState = currentState;
}

function checkState() {
  var currentState = app.getState();

  if (currentState.toUpperCase() === "CONECTADO") {
    alert("Você está conectado à VPN. Desconecte primeiro.");
    return false;
  }
}

function capitalizeFirstLetter(string) {
  return string.charAt(0).toUpperCase() + string.slice(1);
}

setInterval(function () {
  updateState();
}, 0);

document.addEventListener("DOMContentLoaded", function () {
  const user = document.getElementById('username');
  const pass = document.getElementById('password');
 

  const usuarioSalvo = localStorage.getItem('usuario');
  const senhaSalva = localStorage.getItem('senha');


  if (usuarioSalvo && senhaSalva) {
    user.value = usuarioSalvo;
    pass.value = senhaSalva;
  }

 
  const configSelecionada = localStorage.getItem('configSelecionada');
  if (configSelecionada) {
    const server = JSON.parse(configSelecionada);
    selectServer(server);
  }
});

async function startCheckuser() {
  try {
    let dataString = localStorage.getItem('checkuser_data') || await app.getCheckuserDados() || "null";
    if (dataString === "null") return;

    const { username = "Sem informações", count_connection = "Sem informações", expiration_date = "Sem informações", expiration_days = "Sem informações", limiter_user = "Sem informações" } = JSON.parse(dataString);

    const elements = {
      'usernamee': username,
      'usernames': username,
      'countConnection': count_connection,
      'expirationDate': expiration_date,
      'expirationDatee': expiration_date,
      'expirationDays': expiration_days,
      'expirationDayss': expiration_days,
      'limiterUser': limiter_user
    };

    Object.keys(elements).forEach(key => {
      document.getElementById(key).textContent = elements[key];
    });

    document.getElementById('caixachecker').style.display = "block";


  } catch (error) {
    console.error("Erro ao buscar dados do usuário:", error);
  }
}
const logoImg = document.getElementById("logoImg");

logoImg.src = app.getLogoUrl();



const openConfigModalButton = document.getElementById('openConfigModalButton');

openConfigModalButton.addEventListener('click', function () {
  showModal();
});

function showModal() {
  const containerServers = document.getElementById('container-servers');
  containerServers.classList.remove('scale-0');
}

const modal = document.getElementById('container-servers');
const serverOptions = document.getElementById('serverOptions');
serverOptions.classList.add('flex', 'flex-col', 'items-start', 'overflow-y-auto');
serverOptions.style.maxHeight = "calc(100% - 70px)";
serverOptions.style.overflowY = "auto";

const servers = JSON.parse(app.getJsonServers());

servers.forEach(function (server) {
  const card = createServerCard(server);
  serverOptions.appendChild(card);
});

function createServerCard(server) {
  const card = document.createElement('div');
  card.classList.add('set-configs', 'flex', 'flex-col', 'items-center', 'cursor-pointer', 'transition-all', 'duration-300', 'ease-in-out', 'transform', 'hover:scale-105');

  const radioInput = document.createElement('input');
  radioInput.classList.add('peer', 'hidden');
  radioInput.type = 'radio';
  radioInput.name = 'config';
  radioInput.id = server.ConfigId;
  card.appendChild(radioInput);

  const label = document.createElement('label');
  label.classList.add('w-full', 'p-4', 'border', 'border-[#01010342]', 'rounded-md', 'overflow-hidden');
  label.style.height = '50px';
  label.htmlFor = server.ConfigId;
  card.appendChild(label);

  const header = document.createElement('header');
  header.classList.add('w-full', 'h-16', 'flex', 'items-center', 'justify-center', 'p-2', 'bg-gray-200', 'rounded-t-md');
  label.appendChild(header);

  const title = document.createElement('h1');
  title.classList.add('text-lg', 'font-semibold', 'text-black', 'truncate');
  title.textContent = server.ConfigName;
  header.appendChild(title);

  
  

  const list = document.createElement('ul');
  list.classList.add('w-full', 'h-auto', 'flex', 'flex-col', 'gap-2', 'p-4', 'overflow-hidden', 'bg-gray-100');
  label.appendChild(list);

  card.addEventListener('click', function () {
    selectServer(server);
  });

  return card;
}

function selectServer(server) {
  const configButton = document.getElementById("openConfigModalButton");
  configButton.textContent = server.ConfigName;
  app.returnConfigId(server.ConfigId);

  localStorage.setItem('configSelecionada', JSON.stringify(server));

  modal.classList.remove('scale-0');
  closeServerModal();
}

modal.addEventListener('click', function (event) {
  if (event.target === modal) {
    modal.classList.add('scale-0');
  }
});

function closeServerModal() {
  const containerServers = document.getElementById('container-servers');
  containerServers.classList.add('scale-0');
}


   

document.body.style.backgroundImage = `url('${app.getBackUrl()}')`;


</script>
</body>
</html>",
  7. "Logoweb":"https://i.ibb.co/7G8fVCq/offline-1.png",
  8. "CheckPop":"true",
  9. "Rodapeweb":"",
  10. "Fundoweb":"https://i.ibb.co/PxbfgpV/papeldeparede.jpg",
  11. "CorMenu":"#47171616",
  12. "CorUserPass":"#FF96921d",
  13. "CorBtcu":"#FF2429c2",
  14. "CorBtcm":"#FF030303",
  15. "CorFundo":"#301631bb",
  16. "WebView":"https://gerenciador.ctunnel.online/renovar/index.php",
  17. "HtmlViewer":"<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    	<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
    <title>Guardian</title>
    <style>
        body  {
            display: flex;
            height: calc(107vh - 4.2rem);
            align-items: flex-end;
            justify-content: center;
            overflow: hidden;
            font-family: sans-serif;
            font-size: 12px;
            color: #656565;
            position: relative;
            margin: 0 auto;
        }

        .menu {
            background: #050C5AE4;
            border-radius: 50px;
            height: 50px;
            width: 50px;
            box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23);
            position: relative;
            overflow: hidden;
            transition: all 1.3s cubic-bezier(0.01, 0.41, 0.63, 1.2);
        }

        ul {
            margin: 0;
            padding: 0;
            visibility: hidden;
            position: absolute;
            display: flex;
            justify-content: space-between;
            left: 80%;
            width: 70%;
            top: 50%;
            height: 100%;
            transform: translate(0, -50%);
            transition: all 0.7s ease 0.1s;
        }

        li {
            list-style: none;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        li span {
            transform: rotateY(50deg);
            opacity: 0;
            transition: opacity 0.9s linear, transform 1.2s linear;
        }

        button {
            border: none;
            background: transparent;
            width: 50px;
            height: 50px;
            position: absolute;
            left: 0;
            transition: all 1s ease;
        }

        button svg {
            stroke: #2196F3;
        }

        button:before {
            position: absolute;
            content: '';
            height: 4px;
            background: #2196f3;
            transform: rotate(180deg);
            left: 0;
            right: 0;
            margin: 0 auto;
            top: 35%;
            width: 40%;
            transition: all 1.1s cubic-bezier(0.25, -0.09, 0.72, 1.47);
        }

        button:after {
            position: absolute;
            content: '';
            height: 4px;
            background: #2196f3;
            left: 0;
            right: 0;
            transform: rotate(-180deg);
            margin: 0 auto;
            top: 55%;
            width: 40%;
            transition: all 1.1s cubic-bezier(0.25, -0.09, 0.72, 1.47);
        }

        .active {
            width: 400px;         
            transition: all 1.3s cubic-bezier(0.01, 0.41, 0.63, 1.2);
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .active ul {
            visibility: visible;
            left: 20px;
            transition: all 1s ease 0.1s;
        }

        .active li span {
            transform: rotateY(0);
            opacity: 1;
            transition: opacity 0.9s linear, transform 1.2s linear;
        }

        .active button {
            left: 85%;
            display: flex;
            align-items: center;
            transition: all 1s ease;
        }

        .active button:before {
            transform: rotate(-45deg);
            top: 50%;
            transition: all 0.5s cubic-bezier(0.25, -0.09, 0.72, 1.47);
        }

        .active button:after {
            transform: rotate(45deg);
            top: 50%;
            transition: all 0.5s cubic-bezier(0.25, -0.09, 0.72, 1.47);
        }

        .size {
            color: var(--icon-color);
            filter: drop-shadow(0 0 0.2rem #a7a7a7);
            width: 2rem;
            height: 2rem;

        }

        .item {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
        }

        .item span {
            color: #FFF;
            font-weight: bold;
        }
        
        .esquerda {
	display: flex;
	gap: 0.5rem;
	position: absolute;
	top: 0;
	left: 10px;
	color: #fff;
	font-weight: bold;
	font-size: 1rem;
	}
	
	.direita {
	display: flex;
	position: absolute;
	top: 0;
	right: 10px;
	color: #fff;
	font-weight: bold;
	font-size: 1rem;
	}
	
	#txtbtn.color {
  color: green;
    }
    </style>
</head>

<body style="background-color: transparent;">
    <div class="menu">
        <button></button>
        <ul>
            <li class="item" onclick="app.runCheckUser()">
                <img class="size" src="https://raw.githubusercontent.com/GuardianOFC/main/main/1689690682289.png">
                <span class="text-item">VALIDADE</span>
            </li>            
            <li class="item" onclick="app.openBatteryOptimization()">
                <img class="size" src="https://raw.githubusercontent.com/GuardianOFC/main/main/1689689175465.png">
                <span class="text-item">BATERIA</span>
            </li>
            <li class="item" onclick="app.openHostpot()">
                <img class="size" src="https://raw.githubusercontent.com/GuardianOFC/main/main/1689690162353.png">
                <span class="text-item">ROTEADOR</span>
            </li>
            <li class="item" onclick="app.openApn()" >
                <img class="size" src="
                https://raw.githubusercontent.com/GuardianOFC/main/main/1689690538787.png">
                <span id="txtbtn" class="text-item">APN</span>
            </li>
        </ul>
    </div>    
    <script>
        var input = document.querySelector('.menu');
        var button = document.querySelector('button');
        button.addEventListener('click', function (e) {
            e.preventDefault();
            input.classList.toggle('active');
        })
    </script>
    <script>
        class AndroidMock {
            static getLocalIP() {
                return '192.168.0.1';
            }
    
            static getConfig() {
                return JSON.stringify({
                    urlCheckUser: 'URLAQUI'
                });
            }
    
            static getNetworkName() {
                return 'REDE';
            }
    
            static openRadioInfo() {
                console.log('openRadioInfo');
            }
        }
    </script>

</body>

</html> ",
  18. "Roteador":"true",
  19. "Servers":[
  20. {
  21. "id":"10473",
  22. "Name":"VIVO WEBSOCKET 3",
  23. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  24. "Payload":"[split]GET HTTP/1.1[crlf][crlf]QUIC/11:80 Ua[crlf]",
  25. "config_v2ray":"",
  26. "v2ray_uuid":"",
  27. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  28. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  29. "ServerPort":"80",
  30. "SSLPort":"443",
  31. "SNI":"",
  32. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  33. "ProxyPort":"80",
  34. "USER":"",
  35. "PASS":"",
  36. "Info":"Proxy"
  37. },
  38. {
  39. "id":"10483",
  40. "Name":"vivo 80 Direct 3",
  41. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  42. "Payload":"split]PUT / HTTP/1.1[crlf]Host: [rotate=m.wechat.com;m.whatsapp.net;redirector.gvt1.com][crlf]Connection: Keep-Alive[crlf]User-Agent: [ua][crlf]Referer: ][crlf]Upgrade: Websocket[crlf]Connection: Keep-Alive[crlf]Upgrade: websocket[crlf][crlf",
  43. "config_v2ray":"",
  44. "v2ray_uuid":"",
  45. "ServerIP":"168.138.130.75",
  46. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  47. "ServerPort":"80",
  48. "SSLPort":"443",
  49. "SNI":"",
  50. "ProxyIP":"",
  51. "ProxyPort":"80",
  52. "USER":"",
  53. "PASS":"",
  54. "Info":"Proxy"
  55. },
  56. {
  57. "id":"10482",
  58. "Name":"vivo 80 Direct 2",
  59. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  60. "Payload":"[split]PUT / HTTP/1.1[crlf]Host: [rotate=m.wechat.com;m.whatsapp.net;redirector.gvt1.com][crlf]X-Forward-Host: ][crlf]Upgrade: Websocket[crlf]Connection: Keep-Alive[crlf]Upgrade: websocket[crlf][crlf",
  61. "config_v2ray":"",
  62. "v2ray_uuid":"",
  63. "ServerIP":"168.138.130.75",
  64. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  65. "ServerPort":"80",
  66. "SSLPort":"443",
  67. "SNI":"",
  68. "ProxyIP":"168.138.130.75",
  69. "ProxyPort":"80",
  70. "USER":"",
  71. "PASS":"",
  72. "Info":"Direct"
  73. },
  74. {
  75. "id":"10481",
  76. "Name":"vivo 80 Direct",
  77. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  78. "Payload":"n[split]PUT / HTTP/1.1[crlf]Host: [rotate=m.wechat.com;m.whatsapp.net;redirector.gvt1.com][crlf]X-Online-Host: ][crlf]Upgrade: Websocket[crlf]Connection: Keep-Alive[crlf]Upgrade: websocket[crlf][crlf]",
  79. "config_v2ray":"",
  80. "v2ray_uuid":"",
  81. "ServerIP":"168.138.130.75",
  82. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  83. "ServerPort":"80",
  84. "SSLPort":"443",
  85. "SNI":"",
  86. "ProxyIP":"168.138.130.75",
  87. "ProxyPort":"80",
  88. "USER":"",
  89. "PASS":"",
  90. "Info":"Proxy"
  91. },
  92. {
  93. "id":"10477",
  94. "Name":"VIVO WEBSOCKET SECURITY 8080 2",
  95. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  96. "Payload":"[delay_split][lf]GET / HTTP/1.1[lf]Host: portal.vivo.com.brnnn n",
  97. "config_v2ray":"",
  98. "v2ray_uuid":"",
  99. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  100. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  101. "ServerPort":"80",
  102. "SSLPort":"443",
  103. "SNI":"",
  104. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  105. "ProxyPort":"80",
  106. "USER":"",
  107. "PASS":"",
  108. "Info":"Proxy"
  109. },
  110. {
  111. "id":"10476",
  112. "Name":"VIVO WEBSOCKET 4",
  113. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  114. "Payload":"[split][delay_split]ACL / /n",
  115. "config_v2ray":"",
  116. "v2ray_uuid":"",
  117. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  118. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  119. "ServerPort":"80",
  120. "SSLPort":"443",
  121. "SNI":"",
  122. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  123. "ProxyPort":"80",
  124. "USER":"",
  125. "PASS":"",
  126. "Info":"Proxy"
  127. },
  128. {
  129. "id":"10475",
  130. "Name":"VIVO WEBSOCKET SECURITY 8080 1",
  131. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  132. "Payload":"ACL http://1.1.1.1rotate=buzzfeed.com;mobile.adobe.com;1.0.0.5 HTTP/1.1[crlf]Host: http://1.1.1.1rotate=buzzfeed.com;myspace.com;mobile.google.com;1.0.0.5[crlf]",
  133. "config_v2ray":"",
  134. "v2ray_uuid":"",
  135. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  136. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  137. "ServerPort":"8080",
  138. "SSLPort":"443",
  139. "SNI":"",
  140. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  141. "ProxyPort":"8080",
  142. "USER":"",
  143. "PASS":"",
  144. "Info":"Proxy"
  145. },
  146. {
  147. "id":"10474",
  148. "Name":"VIVO WEBSOCKET SECURITY ",
  149. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  150. "Payload":"[split] [crlf]GET ua.com@[host_port][protocol][crlf]CONNECT [host_port][protocol][crlf][crlf]",
  151. "config_v2ray":"",
  152. "v2ray_uuid":"",
  153. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  154. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  155. "ServerPort":"80",
  156. "SSLPort":"443",
  157. "SNI":"",
  158. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  159. "ProxyPort":"80",
  160. "USER":"",
  161. "PASS":"",
  162. "Info":"Proxy"
  163. },
  164. {
  165. "id":"10460",
  166. "Name":"vivo 80 IPV6",
  167. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  168. "Payload":"[delay_split] ACL / HTTP/1.1[crlf]Host:[random= 104.18.6.80;104.18.7.80;162.159.138.6;162.159.128.7;104.17.70.206;104.17.71.206;104.17.72.206;104.17.73.206;104.17.74.206;172.64.144.109;104.18.43.147;104.18.7.41][crlf]Connection: Upgrade[crlf]Upgrade: Websocket[crlf][crlf]",
  169. "config_v2ray":"",
  170. "v2ray_uuid":"",
  171. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  172. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  173. "ServerPort":"8080",
  174. "SSLPort":"443",
  175. "SNI":"",
  176. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  177. "ProxyPort":"8080",
  178. "USER":"",
  179. "PASS":"",
  180. "Info":"Proxy"
  181. },
  182. {
  183. "id":"10472",
  184. "Name":"VIVO WEBSOCKET 2",
  185. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  186. "Payload":"[split]GET HTTP/1.1[crlf][crlf]HTTP/2: [crlf]",
  187. "config_v2ray":"",
  188. "v2ray_uuid":"",
  189. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  190. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  191. "ServerPort":"80",
  192. "SSLPort":"443",
  193. "SNI":"",
  194. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  195. "ProxyPort":"80",
  196. "USER":"",
  197. "PASS":"",
  198. "Info":"Proxy"
  199. },
  200. {
  201. "id":"10471",
  202. "Name":"VIVO WEBSOCKET",
  203. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  204. "Payload":"[split]GET HTTP/1.1[crlf][crlf]QUICK/11: Ua[crlf]",
  205. "config_v2ray":"",
  206. "v2ray_uuid":"",
  207. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  208. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  209. "ServerPort":"80",
  210. "SSLPort":"443",
  211. "SNI":"",
  212. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  213. "ProxyPort":"80",
  214. "USER":"",
  215. "PASS":"",
  216. "Info":"Proxy"
  217. },
  218. {
  219. "id":"10479",
  220. "Name":"vivo teste ",
  221. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  222. "Payload":": [rotate= portal.vivo.com.br;portalrecarga.vivo.com.br/recarga/home/;meuplano.tim.com.br;www.vivo.com.br;buzzfeed.com;mobile.adobe.com;1.0.0.5;1.1.1.1;buzzfeed.com;myspace.com;mobile.google.com;1.0.0.5;spotify.com;pagamentonline.emis.co.ao;playwaze.com;wazer.com;soundwaze.com;escolas.playwaze.com;www.wazeunlimited.com;bucs.playwaze.com;ftp.chillwaze.com;unpkg.com;c6bank.com.br;helpypro.stoodi.com.br;atendimento.lojadointer.com.br;creatorsupport.deezer.com:80;itsupport.surveymonkey.com;linefriendshelp.zendesk.com;vivo.interflashplusvpnpro.cloud;m2.interflashplusvpnpro.cloud][crlf][crlf][crlf]",
  223. "config_v2ray":"",
  224. "v2ray_uuid":"",
  225. "ServerIP":"168.138.130.75",
  226. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  227. "ServerPort":"80",
  228. "SSLPort":"443",
  229. "SNI":"",
  230. "ProxyIP":"168.138.130.75",
  231. "ProxyPort":"80",
  232. "USER":"",
  233. "PASS":"",
  234. "Info":"Proxy"
  235. },
  236. {
  237. "id":"10480",
  238. "Name":"vivo teste 2",
  239. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  240. "Payload":": [rotate= portal.vivo.com.br;portalrecarga.vivo.com.br/recarga/home/;meuplano.tim.com.br;www.vivo.com.br;buzzfeed.com;mobile.adobe.com;1.0.0.5;1.1.1.1;buzzfeed.com;myspace.com;mobile.google.com;1.0.0.5;spotify.com;pagamentonline.emis.co.ao;playwaze.com;wazer.com;soundwaze.com;escolas.playwaze.com;www.wazeunlimited.com;bucs.playwaze.com;ftp.chillwaze.com;unpkg.com;c6bank.com.br;helpypro.stoodi.com.br;atendimento.lojadointer.com.br;creatorsupport.deezer.com:80;itsupport.surveymonkey.com;linefriendshelp.zendesk.com;vivo.interflashplusvpnpro.cloud;m2.interflashplusvpnpro.cloud][crlf][crlf][crlf]",
  241. "config_v2ray":"",
  242. "v2ray_uuid":"",
  243. "ServerIP":"168.138.130.75",
  244. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  245. "ServerPort":"80",
  246. "SSLPort":"443",
  247. "SNI":"",
  248. "ProxyIP":"168.138.130.75",
  249. "ProxyPort":"80",
  250. "USER":"",
  251. "PASS":"",
  252. "Info":"Proxy"
  253. },
  254. {
  255. "id":"10470",
  256. "Name":"VIVO SERVIDOR 2",
  257. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  258. "Payload":"[delay_split][rotate=ACL;GET;PUT;CONNECT;HEAD;DEBELETE;DELETE;PROPATCH;PATCH;TRACE;POST] / HTTP/1.1[crlf]Host: vigia.vivo.com.br[crlf]Upgrade: Upgrade[crlf]Connection: Upgrade[crlf][crlf]",
  259. "config_v2ray":"",
  260. "v2ray_uuid":"",
  261. "ServerIP":"129.148.21.218",
  262. "CheckUser":"http://gdhost.space/api/168.138.130.75:5454/checkUser",
  263. "ServerPort":"80",
  264. "SSLPort":"443",
  265. "SNI":"",
  266. "ProxyIP":"129.148.21.218",
  267. "ProxyPort":"80",
  268. "USER":"",
  269. "PASS":"",
  270. "Info":"Proxy"
  271. },
  272. {
  273. "id":"10468",
  274. "Name":"VIVO 4 port 80",
  275. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  276. "Payload":"[delay_split][rotate=ACL;GET;PUT;CONNECT;HEAD;DEBELETE;DELETE;PROPATCH;PATCH;TRACE;POST] / HTTP/1.1[crlf]Host: vigia.vivo.com.br[crlf]Upgrade: Upgrade[crlf]Connection: Upgrade[crlf][crlf]",
  277. "config_v2ray":"",
  278. "v2ray_uuid":"",
  279. "ServerIP":"168.138.130.75",
  280. "CheckUser":"http://gdhost.space/api/168.138.130.75:5454/checkUser",
  281. "ServerPort":"8080",
  282. "SSLPort":"443",
  283. "SNI":"",
  284. "ProxyIP":"168.138.130.75",
  285. "ProxyPort":"8080",
  286. "USER":"",
  287. "PASS":"",
  288. "Info":"Proxy"
  289. },
  290. {
  291. "id":"10467",
  292. "Name":"VIVO 4 port 8080",
  293. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  294. "Payload":"[delay_split][rotate=ACL;GET;PUT;CONNECT;HEAD;DEBELETE;DELETE;PROPATCH;PATCH;TRACE;POST] / HTTP/1.1[crlf]Host: vigia.vivo.com.br[crlf]Upgrade: Upgrade[crlf]Connection: Upgrade[crlf][crlf]",
  295. "config_v2ray":"",
  296. "v2ray_uuid":"",
  297. "ServerIP":"168.138.130.75",
  298. "CheckUser":"http://gdhost.space/api/168.138.130.75:5454/checkUser",
  299. "ServerPort":"8080",
  300. "SSLPort":"443",
  301. "SNI":"",
  302. "ProxyIP":"168.138.130.75",
  303. "ProxyPort":"8080",
  304. "USER":"",
  305. "PASS":"",
  306. "Info":"Proxy"
  307. },
  308. {
  309. "id":"10466",
  310. "Name":"VIVO 3 delay slip 8080",
  311. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  312. "Payload":"[delay_split][rotate=HEAD;GET;UPDATE;ACL;BDELETE;BMOVE;BPROPFIND;LOCK;MERGE;MKCOL;MOVE;NOTIFY;ORDERPATCH;PATCH;POLL;PROPFIND;SEARCH;SUBSCRIBE;UNSUBSCRIBE;UNLOCK] / HTTP /1.2 Host: [random=portal.vivo.com.br;portalrecarga.vivo.com.br/recarga/home/;meuplano.tim.com.br;www.vivo.com.br;buzzfeed.com;mobile.adobe.com;1.0.0.5;1.1.1.1;buzzfeed.com;myspace.com;mobile.google.com;1.0.0.5;spotify.com;pagamentonline.emis.co.ao;playwaze.com;wazer.com;soundwaze.com;escolas.playwaze.com;www.wazeunlimited.com;bucs.playwaze.com;ftp.chillwaze.com;unpkg.com;c6bank.com.br;helpypro.stoodi.com.br;atendimento.lojadointer.com.br;creatorsupport.deezer.com;itsupport.surveymonkey.com;linefriendshelp.zendesk.com;vivo.interflashplusvpnpro.cloud;m2.interflashplusvpnpro.cloud;portalrecarga.vivo.com.br/recarga/home/;meuplano.tim.com.br;www.vivo.com.br;buzzfeed.com;mobile.adobe.com;1.0.0.5;1.1.1.1;buzzfeed.com;myspace.com;mobile.google.com;1.0.0.5;spotify.com;pagamentonline.emis.co.ao;playwaze.com;wazer.com;soundwaze.com;escolas.playwaze.com;www.wazeunlimited.com;bucs.playwaze.com;ftp.chillwaze.com;unpkg.com;c6bank.com.br;helpypro.stoodi.com.br;atendimento.lojadointer.com.br;creatorsupport.deezer.com;itsupport.surveymonkey.com;linefriendshelp.zendesk.com;vivo.interflashplusvpnpro.cloud;m2.interflashplusvpnpro.cloud;soilelementhitdrawsit.org;atrytgoi.com;domoneysincemeanquart.org;fontbit.io;teethlistentrainwhosheet.org;vivoturbo.com.br;label.com.co.il.web.whatsapp.com;vivofibra.com.br;unpkg.com;storema.us][lf]Upgrade: websocket[lf]User-Agent: Googlebot/2.1 (+http://www.google.com/bot.html)[lf][lf][lf]",
  313. "config_v2ray":"",
  314. "v2ray_uuid":"",
  315. "ServerIP":"168.138.130.75",
  316. "CheckUser":"http://gdhost.space/api/168.138.130.75:5454/checkUser",
  317. "ServerPort":"8080",
  318. "SSLPort":"443",
  319. "SNI":"",
  320. "ProxyIP":"168.138.130.75",
  321. "ProxyPort":"8080",
  322. "USER":"",
  323. "PASS":"",
  324. "Info":"Proxy"
  325. },
  326. {
  327. "id":"10465",
  328. "Name":"VIVO 3 ",
  329. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  330. "Payload":"[delay_split][lf]GET / HTTP/1.1[lf]Host: vivo.com.br[lf]",
  331. "config_v2ray":"",
  332. "v2ray_uuid":"",
  333. "ServerIP":"168.138.130.75",
  334. "CheckUser":"http://gdhost.space/api/168.138.130.75:5454/checkUser",
  335. "ServerPort":"80",
  336. "SSLPort":"443",
  337. "SNI":"",
  338. "ProxyIP":"168.138.130.75",
  339. "ProxyPort":"80",
  340. "USER":"",
  341. "PASS":"",
  342. "Info":"Proxy"
  343. },
  344. {
  345. "id":"10463",
  346. "Name":"VIVO 2 80 IPV6",
  347. "FLAG":"https://i.imgur.com/V1ZxzjQ.png",
  348. "Payload":"ACL 127.0.0.1:80[instant_split]ACL www.veek.com.br HTTP/1.1[crlf][crlf]",
  349. "config_v2ray":"",
  350. "v2ray_uuid":"",
  351. "ServerIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  352. "CheckUser":"https://gerenciador.ctunnel.online/apiproxy/proxy.php?url=http://168.138.130.75:5454/checkUser",
  353. "ServerPort":"80",
  354. "SSLPort":"443",
  355. "SNI":"",
  356. "ProxyIP":"0000:0000:0000:0000:0000:ffff:a88a:824b",
  357. "ProxyPort":"80",
  358. "USER":"",
  359. "PASS":"",
  360. "Info":"Proxy"
  361. }
  362. ]
  363. }

comments powered by Disqus