신범기*_*신범기 2 javascript firebase google-cloud-functions google-cloud-firestore
我正在尝试从 api 获取股票数据。
我希望它在每个中午 12:00 更新。
但是当我尝试部署这个功能时,使用
$firebase 部署 --only 函数
错误就出来了。
错误:无法从源加载函数定义:无法从函数源生成清单:RangeError:超出最大调用堆栈大小
这是 funtions/src 中的“index.ts”。
import * as functions from "firebase-functions";
import axios from "axios"
import { doc, getFirestore, setDoc, Timestamp } from 'firebase/firestore'
import { format } from 'date-fns'
import { initializeApp } from "firebase/app";
const firebaseConfig = {
apiKey: "***********",
authDomain: "****",
projectId: "",
storageBucket: "",
messagingSenderId: "",
appId: "",
measurementId: ""
};
// Initialize Firebase
export const app = initializeApp(firebaseConfig);
export const db = getFirestore(app);
const API_KEY = "****************"
interface Wow {
clpr: string
srtnCd: string
}
const today = new Date();
const yesterday = today.setDate(today.getDate() - 1);
const basDt = format(yesterday, 'yyyyMMdd')
export const getStocks = functions
.region('asia-northeast3')
.pubsub.schedule('12 00 * * *')
.timeZone('Asia/Seoul').onRun(async (context) => {
await axios.get(`https://api.odcloud.kr/api/GetStockSecuritiesInfoService/v1/getStockPriceInfo?numOfRows=3000&resultType=json&basDt=${basDt}&serviceKey=${API_KEY}`)
.then(response => {
const wow: Wow[] = response.data.response.body.items.item
wow.map((v, index) => {
setDoc(doc(db, 'KRX', v.srtnCd), { day: Timestamp.fromDate(today), price: v.clpr })
})
return null;
})
})
Run Code Online (Sandbox Code Playgroud)
另一个功能确实运行良好。但如果我包括这个,它就不起作用了。
我应该怎么办?
sam*_*man 16
因为这是您的functions\src\index.ts
文件,所以您应该只从中导出 Cloud Functions,而不能导出其他任何内容。
所以改变:
// Initialize Firebase
export const app = initializeApp(firebaseConfig);
export const db = getFirestore(app);
Run Code Online (Sandbox Code Playgroud)
到:
// Initialize Firebase
const app = initializeApp(firebaseConfig);
const db = getFirestore(app);
Run Code Online (Sandbox Code Playgroud)
如果您想导出初始化的 Firebase SDK 以在其他地方使用,请将其移至其自己的文件functions\src\firebase.ts
(或类似文件):
// firebase.ts
import { initializeApp } from "firebase-admin/app";
import { getFirestore } from "firebase-admin/firestore";
export const app = initializeApp(); // no arguments uses the default service account
export const db = getFirestore(app);
Run Code Online (Sandbox Code Playgroud)
然后像这样使用它:
import { app, db } from "./firebase.ts"
// NOTE: at time of writing, @google-cloud/firestore still uses the legacy namespaced syntax
db.doc("path/to/some/document")
.set({ /* data */ })
.then(() => console.log('success'))
.catch((err) => console.error('error', err));
Run Code Online (Sandbox Code Playgroud)