HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/quadcode/one-time-popup/node_modules/sass-embedded/dist/lib/src/importer-registry.js
"use strict";
// Copyright 2021 Google LLC. Use of this source code is governed by an
// MIT-style license that can be found in the LICENSE file or at
// https://opensource.org/licenses/MIT.
Object.defineProperty(exports, "__esModule", { value: true });
exports.ImporterRegistry = exports.NodePackageImporter = void 0;
const module_1 = require("module");
const p = require("path");
const url_1 = require("url");
const util_1 = require("util");
const protobuf_1 = require("@bufbuild/protobuf");
const canonicalize_context_1 = require("./canonicalize-context");
const utils = require("./utils");
const proto = require("./vendor/embedded_sass_pb");
const utils_1 = require("./utils");
const entryPointDirectoryKey = Symbol();
class NodePackageImporter {
    [entryPointDirectoryKey];
    constructor(entryPointDirectory) {
        entryPointDirectory = entryPointDirectory
            ? p.resolve(entryPointDirectory)
            : require.main?.filename
                ? p.dirname(require.main.filename)
                : // TODO: Find a way to use `import.meta.main` once
                    // https://github.com/nodejs/node/issues/49440 is done.
                    process.argv[1]
                        ? (0, module_1.createRequire)(process.argv[1]).resolve(process.argv[1])
                        : undefined;
        if (!entryPointDirectory) {
            throw new Error('The Node package importer cannot determine an entry point ' +
                'because `require.main.filename` is not defined. ' +
                'Please provide an `entryPointDirectory` to the `NodePackageImporter`.');
        }
        this[entryPointDirectoryKey] = entryPointDirectory;
    }
}
exports.NodePackageImporter = NodePackageImporter;
/**
 * A registry of importers defined in the host that can be invoked by the
 * compiler.
 */
class ImporterRegistry {
    /** Protocol buffer representations of the registered importers. */
    importers;
    /** A map from importer IDs to their corresponding importers. */
    importersById = new Map();
    /** A map from file importer IDs to their corresponding importers. */
    fileImportersById = new Map();
    /** The next ID to use for an importer. */
    id = 0;
    constructor(options) {
        this.importers = (options?.importers ?? [])
            .map(importer => this.register(importer))
            .concat((options?.loadPaths ?? []).map(path => (0, protobuf_1.create)(proto.InboundMessage_CompileRequest_ImporterSchema, {
            importer: { case: 'path', value: p.resolve(path) },
        })));
    }
    /** Converts an importer to a proto without adding it to `this.importers`. */
    register(importer) {
        const message = (0, protobuf_1.create)(proto.InboundMessage_CompileRequest_ImporterSchema, {});
        if (importer instanceof NodePackageImporter) {
            const importerMessage = (0, protobuf_1.create)(proto.NodePackageImporterSchema, {
                entryPointDirectory: importer[entryPointDirectoryKey],
            });
            message.importer = {
                case: 'nodePackageImporter',
                value: importerMessage,
            };
        }
        else if ('canonicalize' in importer) {
            if ('findFileUrl' in importer) {
                throw new Error('Importer may not contain both canonicalize() and findFileUrl(): ' +
                    (0, util_1.inspect)(importer));
            }
            message.importer = { case: 'importerId', value: this.id };
            message.nonCanonicalScheme =
                typeof importer.nonCanonicalScheme === 'string'
                    ? [importer.nonCanonicalScheme]
                    : (importer.nonCanonicalScheme ?? []);
            this.importersById.set(this.id, importer);
        }
        else {
            message.importer = { case: 'fileImporterId', value: this.id };
            this.fileImportersById.set(this.id, importer);
        }
        this.id += 1;
        return message;
    }
    /** Handles a canonicalization request. */
    canonicalize(request) {
        const importer = this.importersById.get(request.importerId);
        if (!importer) {
            throw utils.compilerError('Unknown CanonicalizeRequest.importer_id');
        }
        const canonicalizeContext = new canonicalize_context_1.CanonicalizeContext(request.containingUrl ? new url_1.URL(request.containingUrl) : null, request.fromImport);
        return (0, utils_1.catchOr)(() => {
            return (0, utils_1.thenOr)(importer.canonicalize(request.url, canonicalizeContext), url => (0, protobuf_1.create)(proto.InboundMessage_CanonicalizeResponseSchema, {
                result: url === null
                    ? { case: undefined }
                    : { case: 'url', value: url.toString() },
                containingUrlUnused: !canonicalizeContext.containingUrlAccessed,
            }));
        }, error => (0, protobuf_1.create)(proto.InboundMessage_CanonicalizeResponseSchema, {
            result: { case: 'error', value: `${error}` },
        }));
    }
    /** Handles an import request. */
    import(request) {
        const importer = this.importersById.get(request.importerId);
        if (!importer) {
            throw utils.compilerError('Unknown ImportRequest.importer_id');
        }
        return (0, utils_1.catchOr)(() => {
            return (0, utils_1.thenOr)(importer.load(new url_1.URL(request.url)), result => {
                if (!result)
                    return (0, protobuf_1.create)(proto.InboundMessage_ImportResponseSchema, {});
                if (typeof result.contents !== 'string') {
                    throw Error(`Invalid argument (contents): must be a string but was: ${result.contents.constructor.name}`);
                }
                if (result.sourceMapUrl && !result.sourceMapUrl.protocol) {
                    throw Error('Invalid argument (sourceMapUrl): must be absolute but was: ' +
                        result.sourceMapUrl);
                }
                return (0, protobuf_1.create)(proto.InboundMessage_ImportResponseSchema, {
                    result: {
                        case: 'success',
                        value: {
                            contents: result.contents,
                            syntax: utils.protofySyntax(result.syntax),
                            sourceMapUrl: result.sourceMapUrl?.toString() ?? '',
                        },
                    },
                });
            });
        }, error => (0, protobuf_1.create)(proto.InboundMessage_ImportResponseSchema, {
            result: { case: 'error', value: `${error}` },
        }));
    }
    /** Handles a file import request. */
    fileImport(request) {
        const importer = this.fileImportersById.get(request.importerId);
        if (!importer) {
            throw utils.compilerError('Unknown FileImportRequest.importer_id');
        }
        const canonicalizeContext = new canonicalize_context_1.CanonicalizeContext(request.containingUrl ? new url_1.URL(request.containingUrl) : null, request.fromImport);
        return (0, utils_1.catchOr)(() => {
            return (0, utils_1.thenOr)(importer.findFileUrl(request.url, canonicalizeContext), url => {
                if (!url) {
                    return (0, protobuf_1.create)(proto.InboundMessage_FileImportResponseSchema, {
                        containingUrlUnused: !canonicalizeContext.containingUrlAccessed,
                    });
                }
                if (url.protocol !== 'file:') {
                    throw (`FileImporter ${(0, util_1.inspect)(importer)} returned non-file: URL ` +
                        +`"${url}" for URL "${request.url}".`);
                }
                return (0, protobuf_1.create)(proto.InboundMessage_FileImportResponseSchema, {
                    result: { case: 'fileUrl', value: url.toString() },
                    containingUrlUnused: !canonicalizeContext.containingUrlAccessed,
                });
            });
        }, error => (0, protobuf_1.create)(proto.InboundMessage_FileImportResponseSchema, {
            result: { case: 'error', value: `${error}` },
        }));
    }
}
exports.ImporterRegistry = ImporterRegistry;
//# sourceMappingURL=importer-registry.js.map