feat&fix(支持私有页面的数据访问): 使用react-notion-x要求的方式进行NotionAPI的配置

(cherry picked from commit d5ae329e2c3a1e18b5fd5fc3507791be9da9b4ed)
This commit is contained in:
anime
2024-12-07 12:53:10 +08:00
parent 1c4cb7b0e4
commit 3a16dadd76
4 changed files with 17 additions and 12 deletions

View File

@@ -0,0 +1,10 @@
import { NotionAPI } from 'notion-client'
import BLOG from '@/blog.config'
export default function getNotionAPI() {
return new NotionAPI({
activeUser: BLOG.NOTION_ACTIVE_USER || null,
authToken: BLOG.NOTION_TOKEN_V2 || null,
userTimeZone: Intl.DateTimeFormat().resolvedOptions().timeZone
})
}

View File

@@ -12,6 +12,7 @@ import {
} from '../utils'
import { extractLangPrefix } from '../utils/pageId'
import { mapImgUrl } from './mapImage'
import getNotionAPI from '@/lib/notion/getNotionAPI'
/**
* 获取页面元素成员属性
@@ -56,7 +57,7 @@ export default async function getPageProperties(
case 'person': {
const rawUsers = val.flat()
const users = []
const api = new NotionAPI({ authToken })
const api = getNotionAPI()
for (let i = 0; i < rawUsers.length; i++) {
if (rawUsers[i][0][1]) {

View File

@@ -2,6 +2,7 @@ import BLOG from '@/blog.config'
import { getDataFromCache, setDataToCache } from '@/lib/cache/cache_manager'
import { NotionAPI } from 'notion-client'
import { deepClone, delay } from '../utils'
import getNotionAPI from '@/lib/notion/getNotionAPI'
/**
* 获取文章内容
@@ -42,11 +43,7 @@ export async function getPageWithRetry(id, from, retryAttempts = 3) {
retryAttempts < 3 ? `剩余重试次数:${retryAttempts}` : ''
)
try {
const authToken = BLOG.NOTION_ACCESS_TOKEN || null
const api = new NotionAPI({
authToken,
userTimeZone: Intl.DateTimeFormat().resolvedOptions().timeZone
})
const api = getNotionAPI()
const start = new Date().getTime()
const pageData = await api.getPage(id)
const end = new Date().getTime()
@@ -166,11 +163,7 @@ export const fetchInBatches = async (ids, batchSize = 100) => {
ids = [ids]
}
const authToken = BLOG.NOTION_ACCESS_TOKEN || null
const api = new NotionAPI({
authToken,
userTimeZone: Intl.DateTimeFormat().resolvedOptions().timeZone
})
const api = getNotionAPI()
let fetchedBlocks = {}
for (let i = 0; i < ids.length; i += batchSize) {