Skip to content

Commit

Permalink
Merge branch 'develop' into 61-Implement-autocompletion-frontend
Browse files Browse the repository at this point in the history
  • Loading branch information
thooyork committed May 10, 2023
2 parents 6391700 + ddeef80 commit 442106f
Show file tree
Hide file tree
Showing 7 changed files with 21 additions and 15 deletions.
2 changes: 1 addition & 1 deletion client/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@fumix/fu-blog-client",
"version": "0.1.0",
"version": "0.2.1",
"scripts": {
"start": "vite --port 5010",
"build": "run-p type-check build-only",
Expand Down
2 changes: 1 addition & 1 deletion common/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@fumix/fu-blog-common",
"version": "0.1.0",
"version": "0.2.1",
"author": "fumiX GmbH & Co KG",
"license": "Apache-2.0",
"scripts": {
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"npm": ">=8.0.0 <10.0.0"
},
"name": "@fumix/fu-blog",
"version": "0.1.0",
"version": "0.2.1",
"workspaces": [
"common",
"client",
Expand Down
2 changes: 1 addition & 1 deletion portal/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@fumix/fu-blog-portal",
"version": "0.1.0",
"version": "0.2.1",
"private": true,
"main": "index.js",
"type": "module",
Expand Down
2 changes: 1 addition & 1 deletion server/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@fumix/fu-blog-server",
"version": "0.1.0",
"version": "0.2.1",
"description": "Backend Server for Blog in Node/Express",
"main": "server.js",
"scripts": {
Expand Down
22 changes: 14 additions & 8 deletions server/src/routes/posts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import { UnauthorizedError } from "../errors/UnauthorizedError.js";
import { MarkdownConverterServer } from "../markdown-converter-server.js";
import { authMiddleware } from "../service/middleware/auth.js";
import { extractJsonBody, extractUploadFiles, multipleFilesUpload } from "../service/middleware/files-upload.js";
import { In } from "typeorm";

const router: Router = express.Router();

Expand All @@ -35,17 +36,22 @@ router.get("/page/:page([0-9]+)/count/:count([0-9]+)/search/:search/operator/:op
// TODO : add createdBy and tags to search results
await AppDataSource.manager
.createQueryBuilder(PostEntity, "post")
.select(["post.*", "ts_rank_cd(sp.post_tsv, to_tsquery(:searchTerm)) as rank", "count(*) over() as count"])
.select(["post.id as post_id", "ts_rank_cd(sp.post_tsv, to_tsquery(:searchTerm)) as rank", "count(*) over() as count"])
.setParameter("searchTerm", searchTerm)
.leftJoin("search_posts", "sp", "sp.post_id = id")
.where("sp.post_tsv @@ to_tsquery(:searchTerm)", { searchTerm: searchTerm })
.orderBy("rank", "DESC")
.offset(skipEntries)
.limit(itemsPerPage)
.getRawMany()
.then((result) => {
const count = result?.map((r) => r.count) as number[];
return res.status(200).json({ data: [result, count[0]] });
.then(async (result) => {
const idArray = result?.map((r) => parseInt(r.post_id)) as number[];
const count = result?.map((r) => parseInt(r.count)) as number[];

await AppDataSource.manager
.getRepository(PostEntity)
.findBy({ id: In(idArray) })
.then((result) => res.status(200).json({ data: [result, count[0]] }));
})
.catch((err) => next(err));
});
Expand Down Expand Up @@ -249,10 +255,10 @@ router.post("/:id(\\d+$)", authMiddleware, multipleFilesUpload, async (req: Requ
} else if (!permissionsForUser(account.user).canEditPost && (account.user.id === null || account.user.id !== post.createdBy?.id)) {
return next(new ForbiddenError());
}
/*
const tagsToUseInPost: TagEntity[] = await getPersistedTagsForPost(body).catch((err) => {

const tagsToUseInPost: TagEntity[] = await getPersistedTagsForPost(post, body).catch((err) => {
throw new InternalServerError(true, "Error getting tags" + err);
});*/
});

AppDataSource.manager
.transaction(async (manager) => {
Expand Down Expand Up @@ -282,7 +288,7 @@ router.post("/:id(\\d+$)", authMiddleware, multipleFilesUpload, async (req: Requ
.getRepository(PostEntity)
.findOneByOrFail({ id: postId })
.then((post) => {
post.tags = [];
post.tags = tagsToUseInPost;
return post;
})
.then((updatedPost) => manager.getRepository(PostEntity).save(updatedPost))
Expand Down
4 changes: 2 additions & 2 deletions server/src/routes/utility.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ const router: Router = express.Router();

let cachedSharepic: { url: string; bytes: Uint8Array } | undefined = undefined;
router.get("/github-sharepic", async (req, res) => {
const timestamp = Math.floor(Date.now() / 3600000);
const timestamp = Math.floor(Date.now() / 3600000); // round down to the hour
const url = `https://opengraph.githubassets.com/${timestamp}/${AppSettings.GITHUB_REPOSITORY_SLUG}`;
if (cachedSharepic && cachedSharepic.url === url) {
if (req.header("If-None-Match") === `${timestamp}`) {
Expand All @@ -30,7 +30,7 @@ router.get("/github-sharepic", async (req, res) => {
}
} else {
const sendCachedBytesOrNotFound = () => {
if (cachedSharepic) {
if (cachedSharepic && cachedSharepic.bytes.length > 0) {
res
.status(200)
.header("ETag", `${timestamp}`)
Expand Down

0 comments on commit 442106f

Please sign in to comment.