fix/file-write

This commit is contained in:
tangly1024.com
2023-03-13 12:47:47 +08:00
parent 9bb490508b
commit a932368bfb
3 changed files with 87 additions and 71 deletions

View File

@@ -3,17 +3,22 @@ import fs from 'fs'
import BLOG from '@/blog.config' import BLOG from '@/blog.config'
export async function generateRobotsTxt() { export async function generateRobotsTxt() {
fs.mkdirSync('./public', { recursive: true }) const content = `
fs.writeFileSync('./public/robots.txt', ` # *
# * User-agent: *
User-agent: * Allow: /
Allow: /
# Host # Host
Host: ${BLOG.LINK} Host: ${BLOG.LINK}
# Sitemaps # Sitemaps
Sitemap: ${BLOG.LINK}/sitemap.xml Sitemap: ${BLOG.LINK}/sitemap.xml
`) `
try {
fs.writeFileSync('robots.txt', content)
fs.writeFileSync('./public/robots.txt', content)
} catch (error) {
console.warn('无法写入文件', error)
}
} }

View File

@@ -5,6 +5,26 @@ import ReactDOMServer from 'react-dom/server'
import { getPostBlocks } from './notion' import { getPostBlocks } from './notion'
import NotionPage from '@/components/NotionPage' import NotionPage from '@/components/NotionPage'
/**
* 生成RSS内容
* @param {*} post
* @returns
*/
const createFeedContent = async post => {
// 加密的文章内容只返回摘要
if (post.password && post.password !== '') {
return post.summary
}
const blockMap = await getPostBlocks(post.id, 'rss-content')
if (blockMap) {
post.blockMap = blockMap
const content = ReactDOMServer.renderToString(<NotionPage post={post} />)
const regexExp =
/<div class="notion-collection-row"><div class="notion-collection-row-body"><div class="notion-collection-row-property"><div class="notion-collection-column-title"><svg.*?class="notion-collection-column-title-icon">.*?<\/svg><div class="notion-collection-column-title-body">.*?<\/div><\/div><div class="notion-collection-row-value">.*?<\/div><\/div><\/div><\/div>/g
return content.replace(regexExp, '')
}
}
export async function generateRss(posts) { export async function generateRss(posts) {
const year = new Date().getFullYear() const year = new Date().getFullYear()
const feed = new Feed({ const feed = new Feed({
@@ -30,28 +50,16 @@ export async function generateRss(posts) {
}) })
} }
fs.mkdirSync('./public/rss', { recursive: true }) try {
fs.writeFileSync('./public/rss/feed.xml', feed.rss2()) fs.mkdirSync('./public/rss', { recursive: true })
fs.writeFileSync('./public/rss/atom.xml', feed.atom1()) fs.writeFileSync('./public/rss/feed.xml', feed.rss2())
fs.writeFileSync('./public/rss/feed.json', feed.json1()) fs.writeFileSync('./public/rss/atom.xml', feed.atom1())
} fs.writeFileSync('./public/rss/feed.json', feed.json1())
fs.mkdirSync('./rss', { recursive: true })
/** fs.writeFileSync('./rss/feed.xml', feed.rss2())
* 生成RSS内容 fs.writeFileSync('./rss/atom.xml', feed.atom1())
* @param {*} post fs.writeFileSync('./rss/feed.json', feed.json1())
* @returns } catch (error) {
*/ console.warn('无法写入文件', error)
const createFeedContent = async post => {
// 加密的文章内容只返回摘要
if (post.password && post.password !== '') {
return post.summary
}
const blockMap = await getPostBlocks(post.id, 'rss-content')
if (blockMap) {
post.blockMap = blockMap
const content = ReactDOMServer.renderToString(<NotionPage post={post} />)
const regexExp =
/<div class="notion-collection-row"><div class="notion-collection-row-body"><div class="notion-collection-row-property"><div class="notion-collection-column-title"><svg.*?class="notion-collection-column-title-icon">.*?<\/svg><div class="notion-collection-column-title-body">.*?<\/div><\/div><div class="notion-collection-row-value">.*?<\/div><\/div><\/div><\/div>/g
return content.replace(regexExp, '')
} }
} }

View File

@@ -3,49 +3,52 @@ import fs from 'fs'
import BLOG from '@/blog.config' import BLOG from '@/blog.config'
export async function generateSitemapXml({ allPages }) { export async function generateSitemapXml({ allPages }) {
fs.mkdirSync('./public', { recursive: true }) const urls = [{
loc: `${BLOG.LINK}`,
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}, {
loc: `${BLOG.LINK}/archive`,
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}, {
loc: `${BLOG.LINK}/category`,
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}, {
loc: `${BLOG.LINK}/tag`,
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}]
const urls = [{ allPages?.forEach(post => {
loc: `${BLOG.LINK}`, urls.push({
lastmod: new Date().toISOString().split('T')[0], loc: `${BLOG.LINK}/${post.slug}`,
changefreq: 'daily' lastmod: new Date(post?.date?.start_date || post?.createdTime).toISOString().split('T')[0],
}, { changefreq: 'daily'
loc: `${BLOG.LINK}/archive`, })
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}, {
loc: `${BLOG.LINK}/category`,
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}, {
loc: `${BLOG.LINK}/tag`,
lastmod: new Date().toISOString().split('T')[0],
changefreq: 'daily'
}]
allPages?.forEach(post => {
urls.push({
loc: `${BLOG.LINK}/${post.slug}`,
lastmod: new Date(post?.date?.start_date || post?.createdTime).toISOString().split('T')[0],
changefreq: 'daily'
}) })
}) const xml = createSitemapXml(urls)
const xml = createSitemapXml(urls) try {
fs.writeFileSync('./public/sitemap.xml', xml) fs.writeFileSync('sitemap.xml', xml)
} fs.writeFileSync('./public/sitemap.xml', xml)
} catch (error) {
console.warn('无法写入文件', error)
}
function createSitemapXml(urls) {
let urlsXml = '' function createSitemapXml(urls) {
urls.forEach(u => { let urlsXml = ''
urlsXml += `<url> urls.forEach(u => {
urlsXml += `<url>
<loc>${u.loc}</loc> <loc>${u.loc}</loc>
<lastmod>${u.lastmod}</lastmod> <lastmod>${u.lastmod}</lastmod>
<changefreq>${u.changefreq}</changefreq> <changefreq>${u.changefreq}</changefreq>
</url> </url>
` `
}) })
return ` return `
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
xmlns:news="http://www.google.com/schemas/sitemap-news/0.9" xmlns:news="http://www.google.com/schemas/sitemap-news/0.9"
xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xhtml="http://www.w3.org/1999/xhtml"
@@ -54,4 +57,4 @@ function createSitemapXml(urls) {
${urlsXml} ${urlsXml}
</urlset> </urlset>
` `
} }