only show user's views
This commit is contained in:
@@ -1,13 +1,13 @@
|
|||||||
import { FastifyReply, FastifyRequest } from "fastify";
|
import { FastifyReply, FastifyRequest } from 'fastify';
|
||||||
import { CreateViewInput, UpdateViewInput } from "./view.schema";
|
import { CreateViewInput, UpdateViewInput } from './view.schema';
|
||||||
import {
|
import {
|
||||||
createView,
|
createView,
|
||||||
deleteView,
|
deleteView,
|
||||||
getView,
|
getView,
|
||||||
listViews,
|
listViews,
|
||||||
updateView,
|
updateView,
|
||||||
} from "./view.service";
|
} from './view.service';
|
||||||
import { PageQueryParams } from "../pagination";
|
import { PageQueryParams } from '../pagination';
|
||||||
|
|
||||||
export async function createViewHandler(
|
export async function createViewHandler(
|
||||||
req: FastifyRequest,
|
req: FastifyRequest,
|
||||||
@@ -29,7 +29,7 @@ export async function getViewHandler(req: FastifyRequest, res: FastifyReply) {
|
|||||||
try {
|
try {
|
||||||
const view = await getView(viewId, req.user.tenantId);
|
const view = await getView(viewId, req.user.tenantId);
|
||||||
if (view === null)
|
if (view === null)
|
||||||
return res.code(404).send({ error: "resource not found" });
|
return res.code(404).send({ error: 'resource not found' });
|
||||||
|
|
||||||
return res.code(200).send(view);
|
return res.code(200).send(view);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@@ -41,8 +41,8 @@ export async function listViewHandler(req: FastifyRequest, res: FastifyReply) {
|
|||||||
const params = req.query as PageQueryParams;
|
const params = req.query as PageQueryParams;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const views = await listViews(params, req.user.tenantId);
|
const views = await listViews(params, req.user);
|
||||||
return res.code(200).send(views);
|
return res.code(200).send({ views: views });
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
@@ -58,7 +58,7 @@ export async function updateViewHandler(
|
|||||||
try {
|
try {
|
||||||
const updatedView = await updateView(viewId, input, req.user.tenantId);
|
const updatedView = await updateView(viewId, input, req.user.tenantId);
|
||||||
if (!updatedView)
|
if (!updatedView)
|
||||||
return res.code(404).send({ error: "resource not found" });
|
return res.code(404).send({ error: 'resource not found' });
|
||||||
|
|
||||||
return res.code(200).send(updateView);
|
return res.code(200).send(updateView);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@@ -75,7 +75,7 @@ export async function deleteViewHandler(
|
|||||||
try {
|
try {
|
||||||
const deleteResult = await deleteView(viewId);
|
const deleteResult = await deleteView(viewId);
|
||||||
if (deleteResult.deletedCount == 0)
|
if (deleteResult.deletedCount == 0)
|
||||||
return res.code(404).send({ error: "resource not found" });
|
return res.code(404).send({ error: 'resource not found' });
|
||||||
|
|
||||||
return res.code(204).send();
|
return res.code(204).send();
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
import { AuthenticatedUser } from "../auth";
|
import { AuthenticatedUser } from '../auth';
|
||||||
import { getFilterObject, getSortObject, PageQueryParams } from "../pagination";
|
import { getFilterObject, getSortObject, PageQueryParams } from '../pagination';
|
||||||
import { generateId } from "../utils/id";
|
import { generateId } from '../utils/id';
|
||||||
import {
|
import {
|
||||||
CreateViewInput,
|
CreateViewInput,
|
||||||
UpdateViewInput,
|
UpdateViewInput,
|
||||||
viewFields,
|
viewFields,
|
||||||
viewModel,
|
viewModel,
|
||||||
} from "./view.schema";
|
} from './view.schema';
|
||||||
|
|
||||||
export async function createView(
|
export async function createView(
|
||||||
input: CreateViewInput,
|
input: CreateViewInput,
|
||||||
@@ -26,53 +26,22 @@ export async function getView(viewId: string, tenantId: string) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function listViews(params: PageQueryParams, tenantId: string) {
|
export async function listViews(
|
||||||
|
params: PageQueryParams,
|
||||||
|
user: AuthenticatedUser
|
||||||
|
) {
|
||||||
const page = params.page || 1;
|
const page = params.page || 1;
|
||||||
const pageSize = params.pageSize || 10;
|
const pageSize = params.pageSize || 10;
|
||||||
const sortObj = getSortObject(params, viewFields);
|
const sortObj = getSortObject(params, viewFields);
|
||||||
const filterObj = getFilterObject(params, viewFields);
|
const filterObj = getFilterObject(params, viewFields);
|
||||||
|
|
||||||
const viewList = await viewModel.aggregate([
|
return await viewModel.find({
|
||||||
{
|
$and: [
|
||||||
$match: { $and: [{ tenantId: tenantId }, ...filterObj] },
|
{ tenantId: user.tenantId },
|
||||||
},
|
{ createdBy: user.userId },
|
||||||
{
|
...filterObj,
|
||||||
$project: {
|
],
|
||||||
_id: 1,
|
});
|
||||||
pid: 1,
|
|
||||||
name: 1,
|
|
||||||
collection: 1,
|
|
||||||
createdBy: 1,
|
|
||||||
hide: 1,
|
|
||||||
sort: 1,
|
|
||||||
group: 1,
|
|
||||||
filters: 1,
|
|
||||||
match: 1,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
$facet: {
|
|
||||||
metadata: [{ $count: "count" }],
|
|
||||||
data: [
|
|
||||||
{ $sort: sortObj },
|
|
||||||
{ $skip: (page - 1) * pageSize },
|
|
||||||
{ $limit: pageSize },
|
|
||||||
],
|
|
||||||
},
|
|
||||||
},
|
|
||||||
]);
|
|
||||||
|
|
||||||
if (viewList[0].data.length === 0)
|
|
||||||
return { views: [], metadata: { count: 0, page, pageSize } };
|
|
||||||
|
|
||||||
return {
|
|
||||||
permits: viewList[0]?.data,
|
|
||||||
metadata: {
|
|
||||||
count: viewList[0].metadata[0].count,
|
|
||||||
page,
|
|
||||||
pageSize,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function updateView(
|
export async function updateView(
|
||||||
|
|||||||
Reference in New Issue
Block a user