Skip to main content
Glama

MCP Browser Screenshot Server

chrome.jsโ€ข6.84 kB
"use strict"; /** * @license * Copyright 2023 Google Inc. * SPDX-License-Identifier: Apache-2.0 */ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.resolveDownloadUrl = resolveDownloadUrl; exports.resolveDownloadPath = resolveDownloadPath; exports.relativeExecutablePath = relativeExecutablePath; exports.getLastKnownGoodReleaseForChannel = getLastKnownGoodReleaseForChannel; exports.getLastKnownGoodReleaseForMilestone = getLastKnownGoodReleaseForMilestone; exports.getLastKnownGoodReleaseForBuild = getLastKnownGoodReleaseForBuild; exports.resolveBuildId = resolveBuildId; exports.resolveSystemExecutablePath = resolveSystemExecutablePath; exports.compareVersions = compareVersions; const node_path_1 = __importDefault(require("node:path")); const semver_1 = __importDefault(require("semver")); const httpUtil_js_1 = require("../httpUtil.js"); const types_js_1 = require("./types.js"); function folder(platform) { switch (platform) { case types_js_1.BrowserPlatform.LINUX_ARM: case types_js_1.BrowserPlatform.LINUX: return 'linux64'; case types_js_1.BrowserPlatform.MAC_ARM: return 'mac-arm64'; case types_js_1.BrowserPlatform.MAC: return 'mac-x64'; case types_js_1.BrowserPlatform.WIN32: return 'win32'; case types_js_1.BrowserPlatform.WIN64: return 'win64'; } } function resolveDownloadUrl(platform, buildId, baseUrl = 'https://storage.googleapis.com/chrome-for-testing-public') { return `${baseUrl}/${resolveDownloadPath(platform, buildId).join('/')}`; } function resolveDownloadPath(platform, buildId) { return [buildId, folder(platform), `chrome-${folder(platform)}.zip`]; } function relativeExecutablePath(platform, _buildId) { switch (platform) { case types_js_1.BrowserPlatform.MAC: case types_js_1.BrowserPlatform.MAC_ARM: return node_path_1.default.join('chrome-' + folder(platform), 'Google Chrome for Testing.app', 'Contents', 'MacOS', 'Google Chrome for Testing'); case types_js_1.BrowserPlatform.LINUX_ARM: case types_js_1.BrowserPlatform.LINUX: return node_path_1.default.join('chrome-linux64', 'chrome'); case types_js_1.BrowserPlatform.WIN32: case types_js_1.BrowserPlatform.WIN64: return node_path_1.default.join('chrome-' + folder(platform), 'chrome.exe'); } } async function getLastKnownGoodReleaseForChannel(channel) { const data = (await (0, httpUtil_js_1.getJSON)(new URL('https://googlechromelabs.github.io/chrome-for-testing/last-known-good-versions.json'))); for (const channel of Object.keys(data.channels)) { data.channels[channel.toLowerCase()] = data.channels[channel]; delete data.channels[channel]; } return data.channels[channel]; } async function getLastKnownGoodReleaseForMilestone(milestone) { const data = (await (0, httpUtil_js_1.getJSON)(new URL('https://googlechromelabs.github.io/chrome-for-testing/latest-versions-per-milestone.json'))); return data.milestones[milestone]; } async function getLastKnownGoodReleaseForBuild( /** * @example `112.0.23`, */ buildPrefix) { const data = (await (0, httpUtil_js_1.getJSON)(new URL('https://googlechromelabs.github.io/chrome-for-testing/latest-patch-versions-per-build.json'))); return data.builds[buildPrefix]; } async function resolveBuildId(channel) { if (Object.values(types_js_1.ChromeReleaseChannel).includes(channel)) { return (await getLastKnownGoodReleaseForChannel(channel)).version; } if (channel.match(/^\d+$/)) { // Potentially a milestone. return (await getLastKnownGoodReleaseForMilestone(channel))?.version; } if (channel.match(/^\d+\.\d+\.\d+$/)) { // Potentially a build prefix without the patch version. return (await getLastKnownGoodReleaseForBuild(channel))?.version; } return; } function resolveSystemExecutablePath(platform, channel) { switch (platform) { case types_js_1.BrowserPlatform.WIN64: case types_js_1.BrowserPlatform.WIN32: switch (channel) { case types_js_1.ChromeReleaseChannel.STABLE: return `${process.env['PROGRAMFILES']}\\Google\\Chrome\\Application\\chrome.exe`; case types_js_1.ChromeReleaseChannel.BETA: return `${process.env['PROGRAMFILES']}\\Google\\Chrome Beta\\Application\\chrome.exe`; case types_js_1.ChromeReleaseChannel.CANARY: return `${process.env['PROGRAMFILES']}\\Google\\Chrome SxS\\Application\\chrome.exe`; case types_js_1.ChromeReleaseChannel.DEV: return `${process.env['PROGRAMFILES']}\\Google\\Chrome Dev\\Application\\chrome.exe`; } case types_js_1.BrowserPlatform.MAC_ARM: case types_js_1.BrowserPlatform.MAC: switch (channel) { case types_js_1.ChromeReleaseChannel.STABLE: return '/Applications/Google Chrome.app/Contents/MacOS/Google Chrome'; case types_js_1.ChromeReleaseChannel.BETA: return '/Applications/Google Chrome Beta.app/Contents/MacOS/Google Chrome Beta'; case types_js_1.ChromeReleaseChannel.CANARY: return '/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary'; case types_js_1.ChromeReleaseChannel.DEV: return '/Applications/Google Chrome Dev.app/Contents/MacOS/Google Chrome Dev'; } case types_js_1.BrowserPlatform.LINUX_ARM: case types_js_1.BrowserPlatform.LINUX: switch (channel) { case types_js_1.ChromeReleaseChannel.STABLE: return '/opt/google/chrome/chrome'; case types_js_1.ChromeReleaseChannel.BETA: return '/opt/google/chrome-beta/chrome'; case types_js_1.ChromeReleaseChannel.CANARY: return '/opt/google/chrome-canary/chrome'; case types_js_1.ChromeReleaseChannel.DEV: return '/opt/google/chrome-unstable/chrome'; } } } function compareVersions(a, b) { if (!semver_1.default.valid(a)) { throw new Error(`Version ${a} is not a valid semver version`); } if (!semver_1.default.valid(b)) { throw new Error(`Version ${b} is not a valid semver version`); } if (semver_1.default.gt(a, b)) { return 1; } else if (semver_1.default.lt(a, b)) { return -1; } else { return 0; } } //# sourceMappingURL=chrome.js.map

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/seabassgonzalez/mcp-browser-screenshot'

If you have feedback or need assistance with the MCP directory API, please join our Discord server