Skip to main content
Glama

Weather & Stock MCP Server

by Jeetinida
fetchDevel.js5.26 kB
"use strict"; 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()); }); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); /* istanbul ignore file */ const fs_1 = __importDefault(require("fs")); const crypto_1 = __importDefault(require("crypto")); //const FILE_BASE = path.join(__dirname, "..", "..", "tests", "http"); const BASE_URL = new URL("../../tests/http/", import.meta.url); class FakeResponse { constructor(props) { Object.keys(props).forEach((key) => (this[key] = props[key])); const rawHeaders = this.headers; this.headers = new Headers(rawHeaders); this.headers.getSetCookie = () => rawHeaders["set-cookie"]; } json() { return __awaiter(this, void 0, void 0, function* () { return this.bodyJson || JSON.parse(this.body); }); } text() { return __awaiter(this, void 0, void 0, function* () { return this.body; }); } } function urlHash(url) { var hash = crypto_1.default.createHash("sha1"); hash.update(url); return hash.digest("hex"); } const cache = {}; function fetchDevel(url, fetchOptions) { return __awaiter(this, void 0, void 0, function* () { if (process.env.FETCH_DEVEL === "nocache") return yield fetch(url, fetchOptions); // Use query2 for all our tests / fixtures / cache url = url.replace(/^https:\/\/query1.finance.yahoo.com/, "https://query2.finance.yahoo.com"); // Remove crumb param to have consistent cacheable URLs const origUrl = url; url = url.replace(/[?&]crumb=[^?&]+/, ""); // If devel===true, hash the url, otherwise use the value of devel // This allows us to specify our own static filename vs url hash. /* const filename = path.join( FILE_BASE, fetchOptions.devel === true ? urlHash(url) : fetchOptions.devel ); */ const destUrl = new URL("./" + (fetchOptions.devel === true ? urlHash(url) : fetchOptions.devel), BASE_URL); const filename = destUrl.toString(); if (cache[filename]) return cache[filename]; let contentJson, contentObj; try { contentJson = yield fs_1.default.promises.readFile(destUrl, { encoding: "utf8" }); contentObj = JSON.parse(contentJson); } catch (error) { if (error.code === "ENOENT") { const res = yield fetch(origUrl, fetchOptions); const responseHeaders = Object.fromEntries(res.headers.entries()); if (responseHeaders["set-cookie"]) { responseHeaders["set-cookie"] = responseHeaders.getSetCookie(); } contentObj = { request: { url: url, }, response: { ok: res.ok, status: res.status, statusText: res.statusText, headers: responseHeaders, // body: await res.text(), }, }; const contentTypeHeader = contentObj.response.headers["content-type"]; const contentType = contentTypeHeader && contentTypeHeader.split(";")[0]; if (contentType === "application/json") { contentObj.response.bodyJson = yield res.json(); } else { contentObj.response.body = yield res.text(); } contentJson = JSON.stringify(contentObj, null, 2); yield fs_1.default.promises.writeFile(destUrl, contentJson, { encoding: "utf8" }); } else { throw error; } } if (contentObj.request.url !== url && !filename.match(/\.fake\.json$/)) { const message = "URL mismatch - did you want to delete stale cached " + "result or rename to .fake.json?\n\n" + " Requested URL: " + url + "\n" + " Cached URL: " + contentObj.request.url + "\n" + "\n" + "File: " + filename; throw new Error(message); } const res = (cache[filename] = new FakeResponse(contentObj.response)); return res; }); } exports.default = fetchDevel;

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/Jeetinida/stocknews-mcp'

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