T.ME/BIBIL_0DAY
CasperSecurity


Server : Apache/2
System : Linux server-15-235-50-60 5.15.0-164-generic #174-Ubuntu SMP Fri Nov 14 20:25:16 UTC 2025 x86_64
User : gositeme ( 1004)
PHP Version : 8.2.29
Disable Function : exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Directory :  /home/gositeme/.local/lib/code-server-4.102.2/out/node/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/gositeme/.local/lib/code-server-4.102.2/out/node/socket.js
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
    return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
        function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
        step((generator = generator.apply(thisArg, _arguments || [])).next());
    });
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.SocketProxyProvider = void 0;
const fs_1 = require("fs");
const net = __importStar(require("net"));
const path = __importStar(require("path"));
const tls = __importStar(require("tls"));
const emitter_1 = require("../common/emitter");
const util_1 = require("../common/util");
const util_2 = require("./util");
/**
 * Provides a way to proxy a TLS socket. Can be used when you need to pass a
 * socket to a child process since you can't pass the TLS socket.
 */
class SocketProxyProvider {
    constructor() {
        this.onProxyConnect = new emitter_1.Emitter();
        this.proxyPipe = path.join(util_2.paths.runtime, "tls-proxy");
        this.proxyTimeout = 5000;
    }
    /**
     * Stop the proxy server.
     */
    stop() {
        if (this._proxyServer) {
            this._proxyServer.then((server) => server.close());
            this._proxyServer = undefined;
        }
    }
    createProxy(socket) {
        return __awaiter(this, void 0, void 0, function* () {
            if (!(socket instanceof tls.TLSSocket)) {
                return socket;
            }
            yield this.startProxyServer();
            return new Promise((resolve, reject) => {
                const id = (0, util_1.generateUuid)();
                const proxy = net.connect(this.proxyPipe);
                proxy.once("connect", () => proxy.write(id));
                const timeout = setTimeout(() => {
                    listener.dispose();
                    socket.destroy();
                    proxy.destroy();
                    reject(new Error("TLS socket proxy timed out"));
                }, this.proxyTimeout);
                const listener = this.onProxyConnect.event((connection) => {
                    connection.once("data", (data) => {
                        if (!socket.destroyed && !proxy.destroyed && data.toString() === id) {
                            clearTimeout(timeout);
                            listener.dispose();
                            [
                                [proxy, socket],
                                [socket, proxy],
                            ].forEach(([a, b]) => {
                                a.pipe(b);
                                a.on("error", () => b.destroy());
                                a.on("close", () => b.destroy());
                                a.on("end", () => b.end());
                            });
                            resolve(connection);
                        }
                    });
                });
            });
        });
    }
    startProxyServer() {
        return __awaiter(this, void 0, void 0, function* () {
            if (!this._proxyServer) {
                this._proxyServer = this.findFreeSocketPath(this.proxyPipe)
                    .then((pipe) => {
                    this.proxyPipe = pipe;
                    return Promise.all([
                        fs_1.promises.mkdir(path.dirname(this.proxyPipe), { recursive: true }),
                        fs_1.promises.rm(this.proxyPipe, { force: true, recursive: true }),
                    ]);
                })
                    .then(() => {
                    return new Promise((resolve) => {
                        const proxyServer = net.createServer((p) => this.onProxyConnect.emit(p));
                        proxyServer.once("listening", () => resolve(proxyServer));
                        proxyServer.listen(this.proxyPipe);
                    });
                });
            }
            return this._proxyServer;
        });
    }
    findFreeSocketPath(basePath_1) {
        return __awaiter(this, arguments, void 0, function* (basePath, maxTries = 100) {
            let i = 0;
            let path = basePath;
            while ((yield (0, util_2.canConnect)(path)) && i < maxTries) {
                path = `${basePath}-${++i}`;
            }
            return path;
        });
    }
}
exports.SocketProxyProvider = SocketProxyProvider;
//# sourceMappingURL=socket.js.map

CasperSecurity Mini