slate/node_common/data/methods/get-slates-by-user-id.js

42 lines
1.0 KiB
JavaScript
Raw Normal View History

2020-07-27 04:51:51 +03:00
import { runQuery } from "~/node_common/data/utilities";
export default async ({ userId, publicOnly = false }) => {
2020-07-27 04:51:51 +03:00
return await runQuery({
label: "GET_SLATES_BY_USER_ID",
queryFn: async (DB) => {
const hasUser = (id) =>
DB.raw(`?? @> ?::jsonb`, ["data", JSON.stringify({ ownerId: id })]);
const isPublic = () =>
DB.raw(`?? @> ?::jsonb`, ["data", JSON.stringify({ public: true })]);
2020-07-27 04:51:51 +03:00
let query;
if (publicOnly) {
query = await DB.select("*")
.from("slates")
.where(hasUser(userId))
.where(isPublic())
.orderBy("updated_at", "desc");
} else {
query = await DB.select("*")
.from("slates")
.where(hasUser(userId))
.orderBy("updated_at", "desc");
}
2020-07-27 04:51:51 +03:00
if (!query || query.error) {
return [];
}
return JSON.parse(JSON.stringify(query));
2020-07-27 04:51:51 +03:00
},
errorFn: async (e) => {
console.log({
error: true,
decorator: "GET_SLATES_BY_USER_ID",
});
return [];
2020-07-27 04:51:51 +03:00
},
});
};