@voyant-travel/identity 0.119.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +37 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +12 -0
- package/dist/routes.d.ts +740 -0
- package/dist/routes.d.ts.map +1 -0
- package/dist/routes.js +137 -0
- package/dist/schema.d.ts +785 -0
- package/dist/schema.d.ts.map +1 -0
- package/dist/schema.js +102 -0
- package/dist/service.d.ts +290 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +284 -0
- package/dist/validation.d.ts +2 -0
- package/dist/validation.d.ts.map +1 -0
- package/dist/validation.js +1 -0
- package/package.json +72 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routes.d.ts","sourceRoot":"","sources":["../src/routes.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAmBjE,KAAK,GAAG,GAAG;IACT,SAAS,EAAE;QACT,EAAE,EAAE,kBAAkB,CAAA;QACtB,MAAM,CAAC,EAAE,MAAM,CAAA;KAChB,CAAA;CACF,CAAA;AAED,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yDA8KvB,CAAA;AAEJ,MAAM,MAAM,cAAc,GAAG,OAAO,cAAc,CAAA"}
|
package/dist/routes.js
ADDED
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { parseJsonBody, parseQuery } from "@voyant-travel/hono";
|
|
2
|
+
import { Hono } from "hono";
|
|
3
|
+
import { identityService } from "./service.js";
|
|
4
|
+
import { addressListQuerySchema, contactPointListQuerySchema, insertAddressForEntitySchema, insertAddressSchema, insertContactPointForEntitySchema, insertContactPointSchema, insertNamedContactForEntitySchema, insertNamedContactSchema, namedContactListQuerySchema, updateAddressSchema, updateContactPointSchema, updateNamedContactSchema, } from "./validation.js";
|
|
5
|
+
export const identityRoutes = new Hono()
|
|
6
|
+
.get("/named-contacts", async (c) => {
|
|
7
|
+
const query = parseQuery(c, namedContactListQuerySchema);
|
|
8
|
+
return c.json(await identityService.listNamedContacts(c.get("db"), query));
|
|
9
|
+
})
|
|
10
|
+
.post("/named-contacts", async (c) => {
|
|
11
|
+
return c.json({
|
|
12
|
+
data: await identityService.createNamedContact(c.get("db"), await parseJsonBody(c, insertNamedContactSchema)),
|
|
13
|
+
}, 201);
|
|
14
|
+
})
|
|
15
|
+
.get("/named-contacts/:id", async (c) => {
|
|
16
|
+
const row = await identityService.getNamedContactById(c.get("db"), c.req.param("id"));
|
|
17
|
+
if (!row)
|
|
18
|
+
return c.json({ error: "Named contact not found" }, 404);
|
|
19
|
+
return c.json({ data: row });
|
|
20
|
+
})
|
|
21
|
+
.patch("/named-contacts/:id", async (c) => {
|
|
22
|
+
const row = await identityService.updateNamedContact(c.get("db"), c.req.param("id"), await parseJsonBody(c, updateNamedContactSchema));
|
|
23
|
+
if (!row)
|
|
24
|
+
return c.json({ error: "Named contact not found" }, 404);
|
|
25
|
+
return c.json({ data: row });
|
|
26
|
+
})
|
|
27
|
+
.delete("/named-contacts/:id", async (c) => {
|
|
28
|
+
const row = await identityService.deleteNamedContact(c.get("db"), c.req.param("id"));
|
|
29
|
+
if (!row)
|
|
30
|
+
return c.json({ error: "Named contact not found" }, 404);
|
|
31
|
+
return c.json({ success: true });
|
|
32
|
+
})
|
|
33
|
+
.get("/contact-points", async (c) => {
|
|
34
|
+
const query = parseQuery(c, contactPointListQuerySchema);
|
|
35
|
+
return c.json(await identityService.listContactPoints(c.get("db"), query));
|
|
36
|
+
})
|
|
37
|
+
.post("/contact-points", async (c) => {
|
|
38
|
+
return c.json({
|
|
39
|
+
data: await identityService.createContactPoint(c.get("db"), await parseJsonBody(c, insertContactPointSchema)),
|
|
40
|
+
}, 201);
|
|
41
|
+
})
|
|
42
|
+
.get("/contact-points/:id", async (c) => {
|
|
43
|
+
const row = await identityService.getContactPointById(c.get("db"), c.req.param("id"));
|
|
44
|
+
if (!row)
|
|
45
|
+
return c.json({ error: "Contact point not found" }, 404);
|
|
46
|
+
return c.json({ data: row });
|
|
47
|
+
})
|
|
48
|
+
.patch("/contact-points/:id", async (c) => {
|
|
49
|
+
const row = await identityService.updateContactPoint(c.get("db"), c.req.param("id"), await parseJsonBody(c, updateContactPointSchema));
|
|
50
|
+
if (!row)
|
|
51
|
+
return c.json({ error: "Contact point not found" }, 404);
|
|
52
|
+
return c.json({ data: row });
|
|
53
|
+
})
|
|
54
|
+
.delete("/contact-points/:id", async (c) => {
|
|
55
|
+
const row = await identityService.deleteContactPoint(c.get("db"), c.req.param("id"));
|
|
56
|
+
if (!row)
|
|
57
|
+
return c.json({ error: "Contact point not found" }, 404);
|
|
58
|
+
return c.json({ success: true });
|
|
59
|
+
})
|
|
60
|
+
.get("/addresses", async (c) => {
|
|
61
|
+
const query = parseQuery(c, addressListQuerySchema);
|
|
62
|
+
return c.json(await identityService.listAddresses(c.get("db"), query));
|
|
63
|
+
})
|
|
64
|
+
.post("/addresses", async (c) => {
|
|
65
|
+
return c.json({
|
|
66
|
+
data: await identityService.createAddress(c.get("db"), await parseJsonBody(c, insertAddressSchema)),
|
|
67
|
+
}, 201);
|
|
68
|
+
})
|
|
69
|
+
.get("/addresses/:id", async (c) => {
|
|
70
|
+
const row = await identityService.getAddressById(c.get("db"), c.req.param("id"));
|
|
71
|
+
if (!row)
|
|
72
|
+
return c.json({ error: "Address not found" }, 404);
|
|
73
|
+
return c.json({ data: row });
|
|
74
|
+
})
|
|
75
|
+
.patch("/addresses/:id", async (c) => {
|
|
76
|
+
const row = await identityService.updateAddress(c.get("db"), c.req.param("id"), await parseJsonBody(c, updateAddressSchema));
|
|
77
|
+
if (!row)
|
|
78
|
+
return c.json({ error: "Address not found" }, 404);
|
|
79
|
+
return c.json({ data: row });
|
|
80
|
+
})
|
|
81
|
+
.delete("/addresses/:id", async (c) => {
|
|
82
|
+
const row = await identityService.deleteAddress(c.get("db"), c.req.param("id"));
|
|
83
|
+
if (!row)
|
|
84
|
+
return c.json({ error: "Address not found" }, 404);
|
|
85
|
+
return c.json({ success: true });
|
|
86
|
+
})
|
|
87
|
+
.get("/entities/:entityType/:entityId/contact-points", async (c) => {
|
|
88
|
+
const params = c.req.param();
|
|
89
|
+
return c.json({
|
|
90
|
+
data: await identityService.listContactPointsForEntity(c.get("db"), params.entityType, params.entityId),
|
|
91
|
+
});
|
|
92
|
+
})
|
|
93
|
+
.post("/entities/:entityType/:entityId/contact-points", async (c) => {
|
|
94
|
+
const params = c.req.param();
|
|
95
|
+
const body = await parseJsonBody(c, insertContactPointForEntitySchema);
|
|
96
|
+
return c.json({
|
|
97
|
+
data: await identityService.createContactPoint(c.get("db"), {
|
|
98
|
+
...body,
|
|
99
|
+
entityType: params.entityType,
|
|
100
|
+
entityId: params.entityId,
|
|
101
|
+
}),
|
|
102
|
+
}, 201);
|
|
103
|
+
})
|
|
104
|
+
.get("/entities/:entityType/:entityId/addresses", async (c) => {
|
|
105
|
+
const params = c.req.param();
|
|
106
|
+
return c.json({
|
|
107
|
+
data: await identityService.listAddressesForEntity(c.get("db"), params.entityType, params.entityId),
|
|
108
|
+
});
|
|
109
|
+
})
|
|
110
|
+
.post("/entities/:entityType/:entityId/addresses", async (c) => {
|
|
111
|
+
const params = c.req.param();
|
|
112
|
+
const body = await parseJsonBody(c, insertAddressForEntitySchema);
|
|
113
|
+
return c.json({
|
|
114
|
+
data: await identityService.createAddress(c.get("db"), {
|
|
115
|
+
...body,
|
|
116
|
+
entityType: params.entityType,
|
|
117
|
+
entityId: params.entityId,
|
|
118
|
+
}),
|
|
119
|
+
}, 201);
|
|
120
|
+
})
|
|
121
|
+
.get("/entities/:entityType/:entityId/named-contacts", async (c) => {
|
|
122
|
+
const params = c.req.param();
|
|
123
|
+
return c.json({
|
|
124
|
+
data: await identityService.listNamedContactsForEntity(c.get("db"), params.entityType, params.entityId),
|
|
125
|
+
});
|
|
126
|
+
})
|
|
127
|
+
.post("/entities/:entityType/:entityId/named-contacts", async (c) => {
|
|
128
|
+
const params = c.req.param();
|
|
129
|
+
const body = await parseJsonBody(c, insertNamedContactForEntitySchema);
|
|
130
|
+
return c.json({
|
|
131
|
+
data: await identityService.createNamedContact(c.get("db"), {
|
|
132
|
+
...body,
|
|
133
|
+
entityType: params.entityType,
|
|
134
|
+
entityId: params.entityId,
|
|
135
|
+
}),
|
|
136
|
+
}, 201);
|
|
137
|
+
});
|