/
places.ts
executable file
·92 lines (76 loc) · 3.69 KB
/
places.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// Copyright 2020 Vircadia Contributors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
'use strict';
import Config from '@Base/config';
import { Router, RequestHandler, Request, Response, NextFunction } from 'express';
import { setupMetaverseAPI, finishMetaverseAPI, param1FromParams } from '@Route-Tools/middleware';
import { accountFromAuthToken } from '@Route-Tools/middleware';
import { procGetPlacesPlaceId, procDeletePlacesPlaceId } from '../places/placeId';
import { procPostPlaces } from '../places';
import { buildPlaceInfo } from '@Route-Tools/Util';
import { Places } from '@Entities/Places';
import { Maturity } from '@Entities/Sets/Maturity';
import { PaginationInfo } from '@Entities/EntityFilters/PaginationInfo';
import { PlaceFilterInfo } from '@Entities/EntityFilters/PlaceFilterInfo';
import { Domains } from '@Entities/Domains';
const procGetPlaces: RequestHandler = async (req: Request, resp: Response, next: NextFunction) => {
if (req.vAuthAccount) {
const pager = new PaginationInfo();
const placer = new PlaceFilterInfo();
pager.parametersFromRequest(req);
placer.parametersFromRequest(req);
const allPlaces: any[] = [];
for await (const place of Places.enumerateAsync(placer, pager)) {
// Make sure the place "belongs" to the requestor
if (place.domainId) {
const aDomain = await Domains.getDomainWithId(place.domainId);
if (aDomain && aDomain.sponsorAccountId === req.vAuthAccount.id) {
allPlaces.push(await buildPlaceInfo(place));
};
};
};
req.vRestResp.Data = {
'places': allPlaces,
'maturity-categories': Maturity.MaturityCategories
};
pager.addResponseFields(req);
}
else {
req.vRestResp.respondFailure('unauthorized');
};
next();
};
export const name = '/api/v1/user/places';
export const router = Router();
// Some of these are under 'user' as that was a legacy configuration.
router.get( '/api/v1/user/places', [ setupMetaverseAPI, // req.vRESTResp
accountFromAuthToken, // req.vAuthAccount
procGetPlaces,
finishMetaverseAPI ] );
router.post( '/api/v1/user/places',
[ setupMetaverseAPI, // req.vRESTResp
accountFromAuthToken, // req.vAuthAccount
procPostPlaces,
finishMetaverseAPI ] );
router.get( '/api/v1/user/places/:param1',
[ setupMetaverseAPI, // req.vRESTResp
param1FromParams, // req.vParam1
procGetPlacesPlaceId,
finishMetaverseAPI ] );
router.delete( '/api/v1/user/places/:param1',
[ setupMetaverseAPI, // req.vRESTResp
accountFromAuthToken, // req.vAuthAccount
param1FromParams, // req.vParam1
procDeletePlacesPlaceId,
finishMetaverseAPI ] );