lunasqu.ee-nuxt/server/api/blog/index.ts

56 lines
1.3 KiB
TypeScript
Raw Permalink Normal View History

2022-10-16 09:37:13 +00:00
import { readBlogPosts } from '~~/lib/blog/read-posts';
export default defineEventHandler(async (event) => {
const query = getQuery(event);
const include = (content) => {
const dateObj = new Date(content.date);
if (query.year) {
if (Number(query.year) !== dateObj.getFullYear()) {
return false;
}
}
if (query.month) {
if (Number(query.month) !== dateObj.getMonth() + 1) {
return false;
}
}
if (query.day) {
if (Number(query.day) !== dateObj.getDate()) {
return false;
}
}
2022-10-16 11:04:03 +00:00
if (query.tag) {
if (!content.tags?.length || !content.tags.includes(query.tag)) {
return false;
}
}
2022-10-16 09:37:13 +00:00
return true;
};
2022-10-16 13:28:47 +00:00
const posts = await readBlogPosts(
2022-10-16 11:04:03 +00:00
include,
query.render !== 'false',
2022-10-16 12:50:21 +00:00
query.body === 'true'
2022-10-16 11:04:03 +00:00
);
2022-10-16 13:28:47 +00:00
const limit = Number(query.limit) || 10;
const pages = Math.ceil(posts.length / limit);
const page = Math.max(Math.min(Number(query.page) || 1, pages), 1);
const offset = (page - 1) * limit;
if (pages > 1) {
if (page + 1 <= pages) {
appendResponseHeader(event, 'X-Next-Page', (page + 1).toString());
}
appendResponseHeader(event, 'X-Last-Page', pages.toString());
}
return posts.slice(offset, offset + limit);
2022-10-16 09:37:13 +00:00
});