@capibox/bridge-nextjs-client 0.0.11 → 0.0.13
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/README.md +1 -0
- package/dist/index.d.mts +634 -55
- package/dist/index.d.ts +634 -55
- package/dist/index.js +208 -149
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +200 -151
- package/dist/index.mjs.map +1 -1
- package/package.json +5 -3
package/dist/index.mjs
CHANGED
|
@@ -19,200 +19,246 @@ var __async = (__this, __arguments, generator) => {
|
|
|
19
19
|
});
|
|
20
20
|
};
|
|
21
21
|
|
|
22
|
-
// src/
|
|
23
|
-
import
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
"Content-Type": "application/json"
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
};
|
|
22
|
+
// src/lib/api.ts
|
|
23
|
+
import createFetchClient from "openapi-fetch";
|
|
24
|
+
var endpoint = "/api-proxy";
|
|
25
|
+
var $apiClient = createFetchClient({
|
|
26
|
+
baseUrl: endpoint,
|
|
27
|
+
headers: {
|
|
28
|
+
authorization: "Frontend"
|
|
29
|
+
}
|
|
30
|
+
});
|
|
35
31
|
|
|
36
32
|
// src/browser/mail/send-to-recipient.ts
|
|
37
33
|
var sendToRecipient = (data) => __async(null, null, function* () {
|
|
38
|
-
const res = yield
|
|
39
|
-
|
|
40
|
-
|
|
34
|
+
const res = yield $apiClient.POST(
|
|
35
|
+
"/mail/send-to-recipient",
|
|
36
|
+
{
|
|
37
|
+
params: {
|
|
38
|
+
header: {
|
|
39
|
+
authorization: "Frontend"
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
body: data
|
|
43
|
+
}
|
|
41
44
|
);
|
|
42
|
-
|
|
45
|
+
if (!res.data) {
|
|
46
|
+
throw new Error(res.error);
|
|
47
|
+
}
|
|
48
|
+
return res.data;
|
|
43
49
|
});
|
|
44
50
|
|
|
45
51
|
// src/browser/mail/send-to-support.ts
|
|
46
|
-
import { endpoint as endpoint2 } from "@capibox/bridge-interface";
|
|
47
52
|
var sendToSupport = (data) => __async(null, null, function* () {
|
|
48
|
-
const res = yield
|
|
49
|
-
|
|
50
|
-
|
|
53
|
+
const res = yield $apiClient.POST(
|
|
54
|
+
"/mail/send-to-support",
|
|
55
|
+
{
|
|
56
|
+
params: {
|
|
57
|
+
header: {
|
|
58
|
+
authorization: "Frontend"
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
body: data
|
|
62
|
+
}
|
|
51
63
|
);
|
|
52
|
-
|
|
64
|
+
if (!res.data) {
|
|
65
|
+
throw new Error(res.error);
|
|
66
|
+
}
|
|
67
|
+
return res.data;
|
|
53
68
|
});
|
|
54
69
|
|
|
55
70
|
// src/browser/session/append.ts
|
|
56
|
-
|
|
57
|
-
var append = (data) => __async(null, null, function* () {
|
|
58
|
-
const res = yield fetch(
|
|
59
|
-
endpoint3.ENDPOINT_SESSION_APPEND,
|
|
60
|
-
fetchJsonPostOptions(data)
|
|
61
|
-
);
|
|
62
|
-
return yield res.json();
|
|
71
|
+
var append = () => __async(null, null, function* () {
|
|
63
72
|
});
|
|
64
73
|
|
|
65
74
|
// src/server/middleware.ts
|
|
66
|
-
import { NextResponse } from "next/server";
|
|
67
|
-
import { endpoint as endpoint5 } from "@capibox/bridge-interface";
|
|
75
|
+
import { NextResponse, userAgent } from "next/server";
|
|
68
76
|
|
|
69
|
-
// src/server/_utils/
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
)
|
|
77
|
-
{
|
|
78
|
-
method: "POST",
|
|
79
|
-
body: JSON.stringify(yield req.json()),
|
|
80
|
-
headers: serverProxyHeaders()
|
|
81
|
-
}
|
|
82
|
-
);
|
|
83
|
-
return yield res.json();
|
|
84
|
-
});
|
|
85
|
-
var serverProxyHeaders = () => {
|
|
86
|
-
return {
|
|
87
|
-
"Content-Type": "application/json",
|
|
88
|
-
"Authorization": `${process.env.CAPIBOX_ENV}`.toLowerCase() === "prod" ? `${process.env.CAPIBOX_API_KEY}` : "dev"
|
|
77
|
+
// src/server/_utils/is.ts
|
|
78
|
+
var regexes = {
|
|
79
|
+
ipv4: /^(?:(?:\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])\.){3}(?:\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])$/,
|
|
80
|
+
ipv6: /^((?=.*::)(?!.*::.+::)(::)?([\dA-F]{1,4}:(:|\b)|){5}|([\dA-F]{1,4}:){6})((([\dA-F]{1,4}((?!\3)::|:\b|$))|(?!\2\3)){2}|(((2[0-4]|1\d|[1-9])?\d|25[0-5])\.?\b){4})$/i
|
|
81
|
+
};
|
|
82
|
+
function not(func) {
|
|
83
|
+
return function() {
|
|
84
|
+
return !func.apply(null, Array.prototype.slice.call(arguments));
|
|
89
85
|
};
|
|
86
|
+
}
|
|
87
|
+
function existy(value) {
|
|
88
|
+
return value != null;
|
|
89
|
+
}
|
|
90
|
+
function ip(value) {
|
|
91
|
+
return existy(value) && regexes.ipv4.test(value) || regexes.ipv6.test(value);
|
|
92
|
+
}
|
|
93
|
+
function object(value) {
|
|
94
|
+
return Object(value) === value;
|
|
95
|
+
}
|
|
96
|
+
function string(value) {
|
|
97
|
+
return Object.prototype.toString.call(value) === "[object String]";
|
|
98
|
+
}
|
|
99
|
+
var is = {
|
|
100
|
+
existy,
|
|
101
|
+
ip,
|
|
102
|
+
object,
|
|
103
|
+
string,
|
|
104
|
+
not: {
|
|
105
|
+
existy: not(existy),
|
|
106
|
+
ip: not(ip),
|
|
107
|
+
object: not(object),
|
|
108
|
+
string: not(string)
|
|
109
|
+
}
|
|
90
110
|
};
|
|
111
|
+
var is_default = is;
|
|
91
112
|
|
|
92
|
-
// src/server/
|
|
93
|
-
|
|
94
|
-
if (
|
|
95
|
-
return
|
|
113
|
+
// src/server/_utils/client-ip.ts
|
|
114
|
+
function getClientIpFromXForwardedFor(value) {
|
|
115
|
+
if (!is_default.existy(value)) {
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
const forwardedIps = value.split(",").map(function(e) {
|
|
119
|
+
const ip2 = e.trim();
|
|
120
|
+
if (ip2.includes(":")) {
|
|
121
|
+
const splitted = ip2.split(":");
|
|
122
|
+
if (splitted.length === 2) {
|
|
123
|
+
return splitted[0];
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
return ip2;
|
|
127
|
+
});
|
|
128
|
+
for (let i = 0; i < forwardedIps.length; i++) {
|
|
129
|
+
if (is_default.ip(forwardedIps[i])) {
|
|
130
|
+
return forwardedIps[i];
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return null;
|
|
134
|
+
}
|
|
135
|
+
function getClientIp(req) {
|
|
136
|
+
if (req.headers) {
|
|
137
|
+
if (is_default.ip(req.headers["x-client-ip"])) {
|
|
138
|
+
return req.headers["x-client-ip"];
|
|
139
|
+
}
|
|
140
|
+
const xForwardedFor = getClientIpFromXForwardedFor(req.headers["x-forwarded-for"]);
|
|
141
|
+
if (is_default.ip(req.headers["cf-connecting-ip"])) {
|
|
142
|
+
return req.headers["cf-connecting-ip"];
|
|
143
|
+
}
|
|
144
|
+
if (is_default.ip(req.headers["fastly-client-ip"])) {
|
|
145
|
+
return req.headers["fastly-client-ip"];
|
|
146
|
+
}
|
|
147
|
+
if (is_default.ip(req.headers["true-client-ip"])) {
|
|
148
|
+
return req.headers["true-client-ip"];
|
|
149
|
+
}
|
|
150
|
+
if (is_default.ip(req.headers["x-real-ip"])) {
|
|
151
|
+
return req.headers["x-real-ip"];
|
|
152
|
+
}
|
|
153
|
+
if (is_default.ip(req.headers["x-cluster-client-ip"])) {
|
|
154
|
+
return req.headers["x-cluster-client-ip"];
|
|
155
|
+
}
|
|
156
|
+
if (is_default.ip(req.headers["x-forwarded"])) {
|
|
157
|
+
return req.headers["x-forwarded"];
|
|
158
|
+
}
|
|
159
|
+
if (is_default.ip(req.headers["forwarded-for"])) {
|
|
160
|
+
return req.headers["forwarded-for"];
|
|
161
|
+
}
|
|
162
|
+
if (is_default.ip(xForwardedFor)) {
|
|
163
|
+
return xForwardedFor;
|
|
164
|
+
}
|
|
165
|
+
if (is_default.ip(req.headers.forwarded)) {
|
|
166
|
+
return req.headers.forwarded;
|
|
167
|
+
}
|
|
168
|
+
if (is_default.ip(req.headers["x-appengine-user-ip"])) {
|
|
169
|
+
return req.headers["x-appengine-user-ip"];
|
|
170
|
+
}
|
|
96
171
|
}
|
|
97
|
-
if (req.
|
|
98
|
-
|
|
172
|
+
if (is_default.existy(req.connection) && !!req.connection) {
|
|
173
|
+
if (is_default.ip(req.connection.remoteAddress)) {
|
|
174
|
+
return req.connection.remoteAddress;
|
|
175
|
+
}
|
|
176
|
+
if (is_default.existy(req.connection.socket) && !!req.connection.socket && !!req.connection.socket.remoteAddress && is_default.ip(req.connection.socket.remoteAddress)) {
|
|
177
|
+
return req.connection.socket.remoteAddress;
|
|
178
|
+
}
|
|
99
179
|
}
|
|
100
|
-
if (req.
|
|
101
|
-
return
|
|
180
|
+
if (is_default.existy(req.socket) && !!req.socket && !!req.socket.remoteAddress && is_default.ip(req.socket.remoteAddress)) {
|
|
181
|
+
return req.socket.remoteAddress;
|
|
102
182
|
}
|
|
103
|
-
if (req.
|
|
104
|
-
|
|
105
|
-
const proxyBody = {
|
|
106
|
-
email: jsonData.email,
|
|
107
|
-
language: jsonData.language,
|
|
108
|
-
currency: jsonData.currency
|
|
109
|
-
};
|
|
110
|
-
const res = yield fetch(
|
|
111
|
-
req.nextUrl.pathname.replace(
|
|
112
|
-
endpoint5.MAIN_ENDPOINT,
|
|
113
|
-
"https://api.capibox.com"
|
|
114
|
-
).replace("/append", `/${jsonData.uuid}`),
|
|
115
|
-
{
|
|
116
|
-
method: "PUT",
|
|
117
|
-
body: JSON.stringify(proxyBody),
|
|
118
|
-
headers: serverProxyHeaders()
|
|
119
|
-
}
|
|
120
|
-
);
|
|
121
|
-
return yield res.json();
|
|
183
|
+
if (is_default.existy(req.info) && !!req.info && !!req.info.remoteAddress && is_default.ip(req.info.remoteAddress)) {
|
|
184
|
+
return req.info.remoteAddress;
|
|
122
185
|
}
|
|
123
|
-
if (req.
|
|
124
|
-
|
|
125
|
-
"https://auth.crm.apidata.app/api/sign-in",
|
|
126
|
-
{
|
|
127
|
-
method: "POST",
|
|
128
|
-
body: JSON.stringify(yield req.json()),
|
|
129
|
-
headers: serverProxyHeaders()
|
|
130
|
-
}
|
|
131
|
-
);
|
|
132
|
-
const resJson = yield res.json();
|
|
133
|
-
const result = NextResponse.json(resJson);
|
|
134
|
-
if (!!resJson.action && !!resJson.token && resJson.action === "logged-in") {
|
|
135
|
-
result.cookies.set({
|
|
136
|
-
name: "token",
|
|
137
|
-
value: resJson.token,
|
|
138
|
-
maxAge: 60 * 60 * 24 * 30,
|
|
139
|
-
httpOnly: true
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
return result;
|
|
186
|
+
if (is_default.existy(req.requestContext) && !!req.requestContext && is_default.existy(req.requestContext.identity) && !!req.requestContext.identity && !!req.requestContext.identity.sourceIp && is_default.ip(req.requestContext.identity.sourceIp)) {
|
|
187
|
+
return req.requestContext.identity.sourceIp;
|
|
143
188
|
}
|
|
144
|
-
if (req.
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
return NextResponse.json({ success: 0 });
|
|
148
|
-
}
|
|
149
|
-
const payload = {
|
|
150
|
-
data: {
|
|
151
|
-
token: tokenCookie.value
|
|
152
|
-
}
|
|
153
|
-
};
|
|
154
|
-
const res = yield fetch(
|
|
155
|
-
"https://auth.crm.apidata.app/api/check",
|
|
156
|
-
{
|
|
157
|
-
method: "POST",
|
|
158
|
-
body: JSON.stringify(payload),
|
|
159
|
-
headers: serverProxyHeaders()
|
|
160
|
-
}
|
|
161
|
-
);
|
|
162
|
-
const resJson = yield res.json();
|
|
163
|
-
const result = NextResponse.json(resJson);
|
|
164
|
-
if (!("id" in resJson && resJson.id > 0)) {
|
|
165
|
-
result.cookies.delete("token");
|
|
189
|
+
if (req.headers) {
|
|
190
|
+
if (is_default.ip(req.headers["Cf-Pseudo-IPv4"])) {
|
|
191
|
+
return req.headers["Cf-Pseudo-IPv4"];
|
|
166
192
|
}
|
|
167
|
-
return result;
|
|
168
193
|
}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
194
|
+
return "127.0.0.2";
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
// src/server/middleware.ts
|
|
198
|
+
var middleware = (req) => __async(null, null, function* () {
|
|
199
|
+
if (req.nextUrl.pathname.startsWith("/api-proxy")) {
|
|
200
|
+
let urlClone = req.nextUrl.clone();
|
|
201
|
+
const targetUrl = new URL(`${process.env.BACKEND_URL}`);
|
|
202
|
+
const requestHeaders = new Headers(req.headers);
|
|
203
|
+
requestHeaders.set("host", targetUrl.hostname);
|
|
204
|
+
requestHeaders.set("authorization", `${process.env.CAPIBOX_API_KEY}`);
|
|
205
|
+
if (req.nextUrl.pathname.includes("/realtime/")) {
|
|
206
|
+
const ip2 = getClientIp({ headers: Object.fromEntries(req.headers) });
|
|
207
|
+
const { device, browser: browser2, os } = userAgent(req);
|
|
208
|
+
requestHeaders.set("x-client-ip", ip2);
|
|
209
|
+
requestHeaders.set("x-os", `${os.name} / ${os.version}`);
|
|
210
|
+
requestHeaders.set("x-browser", `${browser2.name} / ${browser2.version}`);
|
|
211
|
+
requestHeaders.set("x-device", device.type ? device.type : "-");
|
|
212
|
+
const anUuidV3Cookie = req.cookies.get("an_uuid_v3");
|
|
213
|
+
if (anUuidV3Cookie) {
|
|
214
|
+
requestHeaders.set("x-realtime", anUuidV3Cookie == null ? void 0 : anUuidV3Cookie.value);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
urlClone.protocol = targetUrl.protocol;
|
|
218
|
+
urlClone.hostname = targetUrl.hostname;
|
|
219
|
+
urlClone.port = targetUrl.port;
|
|
220
|
+
urlClone.pathname = urlClone.pathname.replace(/^\/api-proxy/, "");
|
|
221
|
+
return NextResponse.rewrite(urlClone, {
|
|
222
|
+
headers: requestHeaders
|
|
223
|
+
});
|
|
173
224
|
}
|
|
174
225
|
});
|
|
175
226
|
|
|
176
227
|
// src/browser/session/create.ts
|
|
177
|
-
|
|
178
|
-
var create = (data) => __async(null, null, function* () {
|
|
179
|
-
const res = yield fetch(
|
|
180
|
-
endpoint6.ENDPOINT_SESSION_CREATE,
|
|
181
|
-
fetchJsonPostOptions(data)
|
|
182
|
-
);
|
|
183
|
-
return yield res.json();
|
|
228
|
+
var create = () => __async(null, null, function* () {
|
|
184
229
|
});
|
|
185
230
|
|
|
186
231
|
// src/browser/crm-auth/sign-in.ts
|
|
187
|
-
|
|
188
|
-
var signIn = (data) => __async(null, null, function* () {
|
|
189
|
-
const res = yield fetch(
|
|
190
|
-
endpoint7.ENDPOINT_CRM_AUTH_SIGN_IN,
|
|
191
|
-
fetchJsonPostOptions(data)
|
|
192
|
-
);
|
|
193
|
-
return yield res.json();
|
|
232
|
+
var signIn = () => __async(null, null, function* () {
|
|
194
233
|
});
|
|
195
234
|
|
|
196
235
|
// src/browser/crm-auth/sign-out.ts
|
|
197
|
-
import { endpoint as endpoint8 } from "@capibox/bridge-interface";
|
|
198
236
|
var signOut = () => __async(null, null, function* () {
|
|
199
|
-
const res = yield fetch(
|
|
200
|
-
endpoint8.ENDPOINT_CRM_AUTH_SIGN_OUT,
|
|
201
|
-
fetchJsonPostOptions({})
|
|
202
|
-
);
|
|
203
|
-
return yield res.json();
|
|
204
237
|
});
|
|
205
238
|
|
|
206
239
|
// src/browser/crm-auth/veirfy.ts
|
|
207
|
-
import { endpoint as endpoint9 } from "@capibox/bridge-interface";
|
|
208
240
|
var verify = () => __async(null, null, function* () {
|
|
209
|
-
const res = yield fetch(
|
|
210
|
-
endpoint9.ENDPOINT_CRM_AUTH_VERIFY,
|
|
211
|
-
fetchJsonPostOptions({})
|
|
212
|
-
);
|
|
213
|
-
return yield res.json();
|
|
214
241
|
});
|
|
215
242
|
|
|
243
|
+
// src/browser/hooks/useParamsLandingPage.ts
|
|
244
|
+
import { useParams } from "next/navigation";
|
|
245
|
+
var useParamsLandingPage = () => {
|
|
246
|
+
var _a, _b;
|
|
247
|
+
const params = useParams();
|
|
248
|
+
const angle = ((_a = params.landing) != null ? _a : "main").toLowerCase();
|
|
249
|
+
const version = ((_b = params.checkout) != null ? _b : "a").toLowerCase();
|
|
250
|
+
return {
|
|
251
|
+
landing: angle,
|
|
252
|
+
checkout: version,
|
|
253
|
+
angle,
|
|
254
|
+
version,
|
|
255
|
+
path: {
|
|
256
|
+
root: `/${angle}/${version}`,
|
|
257
|
+
rootPretty: angle === "main" && version === "a" ? "" : `/${angle}/${version}`
|
|
258
|
+
}
|
|
259
|
+
};
|
|
260
|
+
};
|
|
261
|
+
|
|
216
262
|
// src/index.ts
|
|
217
263
|
var browser = {
|
|
218
264
|
mail: {
|
|
@@ -227,6 +273,9 @@ var browser = {
|
|
|
227
273
|
signIn,
|
|
228
274
|
signOut,
|
|
229
275
|
verify
|
|
276
|
+
},
|
|
277
|
+
hooks: {
|
|
278
|
+
useParamsLandingPage
|
|
230
279
|
}
|
|
231
280
|
};
|
|
232
281
|
var server = {
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/browser/mail/send-to-recipient.ts","../src/browser/_utils/browser-fetch-utils.ts","../src/browser/mail/send-to-support.ts","../src/browser/session/append.ts","../src/server/middleware.ts","../src/server/_utils/server-fetch-utils.ts","../src/browser/session/create.ts","../src/browser/crm-auth/sign-in.ts","../src/browser/crm-auth/sign-out.ts","../src/browser/crm-auth/veirfy.ts","../src/index.ts"],"sourcesContent":["import {dto, endpoint} from '@capibox/bridge-interface'\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const sendToRecipient = async (data: dto.SendMailRecipientDtoType): Promise<dto.SendMailResponseDtoType> => {\n const res = await fetch(\n endpoint.ENDPOINT_MAIL_SEND_TO_RECIPIENT,\n fetchJsonPostOptions(data)\n )\n return await res.json();\n}","export const fetchJsonPostOptions = (data: any) => {\n return {\n method: 'POST',\n body: JSON.stringify(data),\n headers: {\n 'Content-Type': 'application/json'\n }\n }\n}","import {dto, endpoint} from '@capibox/bridge-interface'\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const sendToSupport = async (data: dto.SendMailSupportDtoType): Promise<dto.SendMailResponseDtoType> => {\n const res = await fetch(\n endpoint.ENDPOINT_MAIL_SEND_TO_SUPPORT,\n fetchJsonPostOptions(data)\n )\n return await res.json();\n}","import {dto, endpoint} from \"@capibox/bridge-interface\";\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const append = async (data: dto.AppendSessionDtoType): Promise<dto.SessionResponseDtoType> => {\n const res = await fetch(\n endpoint.ENDPOINT_SESSION_APPEND,\n fetchJsonPostOptions(data)\n )\n return await res.json();\n}","import {NextRequest, NextResponse} from \"next/server\";\nimport {dto, endpoint} from \"@capibox/bridge-interface\";\nimport {serverProxyHeaders, serverProxyPostRequest} from \"./_utils/server-fetch-utils\";\n\nexport const middleware = async (req: NextRequest) => {\n // mail\n if (req.nextUrl.pathname === endpoint.ENDPOINT_MAIL_SEND_TO_RECIPIENT) {\n return NextResponse.json(await serverProxyPostRequest(req));\n }\n if (req.nextUrl.pathname === endpoint.ENDPOINT_MAIL_SEND_TO_SUPPORT) {\n return NextResponse.json(await serverProxyPostRequest(req));\n }\n\n // session\n if (req.nextUrl.pathname === endpoint.ENDPOINT_SESSION_CREATE) {\n return NextResponse.json(await serverProxyPostRequest(req));\n }\n if (req.nextUrl.pathname === endpoint.ENDPOINT_SESSION_APPEND) {\n const jsonData: dto.AppendSessionBrowserPublicDtoType = await req.json();\n const proxyBody: dto.AppendSessionDtoType = {\n email: jsonData.email,\n language: jsonData.language,\n currency: jsonData.currency,\n };\n\n const res = await fetch(\n req.nextUrl.pathname.replace(\n endpoint.MAIN_ENDPOINT,\n 'https://api.capibox.com'\n ).replace('/append', `/${jsonData.uuid}`),\n {\n method: 'PUT',\n body: JSON.stringify(proxyBody),\n headers: serverProxyHeaders(),\n }\n )\n return await res.json();\n }\n\n // crm auth\n if (req.nextUrl.pathname === endpoint.ENDPOINT_CRM_AUTH_SIGN_IN) {\n const res = await fetch(\n 'https://auth.crm.apidata.app/api/sign-in',\n {\n method: 'POST',\n body: JSON.stringify(await req.json()),\n headers: serverProxyHeaders(),\n }\n )\n const resJson: dto.SignInCrmResponseDtoType = await res.json();\n\n const result = NextResponse.json(resJson);\n if (!!resJson.action && !!resJson.token && resJson.action === 'logged-in') {\n result.cookies.set({\n name: \"token\",\n value: resJson.token,\n maxAge: 60 * 60 * 24 * 30,\n httpOnly: true,\n });\n }\n return result;\n }\n if (req.nextUrl.pathname === endpoint.ENDPOINT_CRM_AUTH_VERIFY) {\n const tokenCookie = req.cookies.get('token')\n if (!tokenCookie || !tokenCookie.value) {\n return NextResponse.json({success: 0})\n }\n\n const payload: dto.VerifyCrmUserDtoType = {\n data: {\n token: tokenCookie.value,\n }\n }\n const res = await fetch(\n 'https://auth.crm.apidata.app/api/check',\n {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: serverProxyHeaders(),\n }\n )\n const resJson: dto.VerifyCrmResponseDtoType = await res.json();\n\n const result = NextResponse.json(resJson);\n if (!('id' in resJson && resJson.id > 0)) {\n result.cookies.delete(\"token\");\n }\n return result;\n }\n if (req.nextUrl.pathname === endpoint.ENDPOINT_CRM_AUTH_SIGN_OUT) {\n const res = NextResponse.json({success: 1});\n res.cookies.delete(\"token\");\n return res;\n }\n}","import {NextRequest} from \"next/server\";\nimport {endpoint} from \"@capibox/bridge-interface\";\n\nexport const serverProxyPostRequest = async (req: NextRequest) => {\n const res = await fetch(\n req.nextUrl.pathname.replace(\n endpoint.MAIN_ENDPOINT,\n 'https://api.capibox.com'\n ),\n {\n method: 'POST',\n body: JSON.stringify(await req.json()),\n headers: serverProxyHeaders(),\n }\n )\n return await res.json();\n}\n\nexport const serverProxyHeaders = () => {\n return {\n 'Content-Type': 'application/json',\n 'Authorization': `${process.env.CAPIBOX_ENV}`.toLowerCase() === 'prod' ? `${process.env.CAPIBOX_API_KEY}` : 'dev'\n }\n}","import {dto, endpoint} from \"@capibox/bridge-interface\";\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const create = async (data: dto.CreateSessionBrowserPublicDtoType): Promise<dto.SessionResponseDtoType> => {\n const res = await fetch(\n endpoint.ENDPOINT_SESSION_CREATE,\n fetchJsonPostOptions(data)\n )\n return await res.json();\n}","import {dto, endpoint} from \"@capibox/bridge-interface\";\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const signIn = async (data: dto.SignInCrmUserDtoType): Promise<dto.SignInCrmResponseDtoType> => {\n const res = await fetch(\n endpoint.ENDPOINT_CRM_AUTH_SIGN_IN,\n fetchJsonPostOptions(data)\n )\n return await res.json();\n}","import {dto, endpoint} from \"@capibox/bridge-interface\";\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const signOut = async (): Promise<{ success: 1 }> => {\n const res = await fetch(\n endpoint.ENDPOINT_CRM_AUTH_SIGN_OUT,\n fetchJsonPostOptions({})\n )\n return await res.json();\n}","import {dto, endpoint} from \"@capibox/bridge-interface\";\nimport {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const verify = async (): Promise<dto.VerifyCrmResponseDtoType> => {\n const res = await fetch(\n endpoint.ENDPOINT_CRM_AUTH_VERIFY,\n fetchJsonPostOptions({})\n )\n return await res.json();\n}","import {sendToRecipient} from \"./browser/mail/send-to-recipient\";\nimport {sendToSupport} from \"./browser/mail/send-to-support\";\nimport { append } from \"./browser/session/append\";\nimport {middleware} from \"./server/middleware\";\nimport {create} from \"./browser/session/create\";\nimport {signIn} from \"./browser/crm-auth/sign-in\";\nimport {signOut} from \"./browser/crm-auth/sign-out\";\nimport {verify} from \"./browser/crm-auth/veirfy\";\n\nconst browser = {\n mail: {\n sendToRecipient,\n sendToSupport,\n },\n session: {\n append,\n create,\n },\n crmAuth: {\n signIn,\n signOut,\n verify,\n }\n}\n\nconst server = {\n middleware\n}\n\nexport {\n browser,\n server\n}\n// v.0.0.11"],"mappings":"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","names":["endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint","endpoint"]}
|
|
1
|
+
{"version":3,"sources":["../src/lib/api.ts","../src/browser/mail/send-to-recipient.ts","../src/browser/mail/send-to-support.ts","../src/browser/session/append.ts","../src/server/middleware.ts","../src/server/_utils/is.ts","../src/server/_utils/client-ip.ts","../src/browser/session/create.ts","../src/browser/crm-auth/sign-in.ts","../src/browser/crm-auth/sign-out.ts","../src/browser/crm-auth/veirfy.ts","../src/browser/hooks/useParamsLandingPage.ts","../src/index.ts"],"sourcesContent":["import createFetchClient from \"openapi-fetch\";\nimport createClient from \"openapi-react-query\";\nimport type {paths} from \"./api.def\";\n\nconst endpoint = '/api-proxy';\n\nexport const $apiClient = createFetchClient<paths>({\n baseUrl: endpoint,\n headers: {\n authorization: \"Frontend\"\n },\n});","import {components} from '../../lib/api.def'\nimport {$apiClient} from \"../../lib/api\";\n\nexport const sendToRecipient = async (data: components['schemas']['SendMailToRecipientDto']): Promise<components['schemas']['SendMailResponseDto']> => {\n const res = await $apiClient.POST(\n '/mail/send-to-recipient',\n {\n params: {\n header: {\n authorization: \"Frontend\"\n }\n },\n body: data,\n }\n )\n if (!res.data) {\n throw new Error(res.error)\n }\n return res.data;\n}","import {components} from '../../lib/api.def'\nimport {$apiClient} from \"../../lib/api\";\n\nexport const sendToSupport = async (data: components['schemas']['SendMailToSupportDto']): Promise<components['schemas']['SendMailResponseDto']> => {\n const res = await $apiClient.POST(\n '/mail/send-to-support',\n {\n params: {\n header: {\n authorization: \"Frontend\"\n }\n },\n body: data,\n }\n )\n if (!res.data) {\n throw new Error(res.error)\n }\n return res.data;\n}","import {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const append = async (): Promise<void> => {\n // const res = await fetch(\n // endpoint.ENDPOINT_SESSION_APPEND,\n // fetchJsonPostOptions(data)\n // )\n // return await res.json();\n}","import {NextRequest, NextResponse, userAgent} from \"next/server\";\nimport {getClientIp} from \"./_utils/client-ip\";\n\nexport const middleware = async (req: NextRequest) => {\n if (req.nextUrl.pathname.startsWith('/api-proxy')) {\n let urlClone = req.nextUrl.clone();\n\n const targetUrl = new URL(`${process.env.BACKEND_URL}`)\n const requestHeaders = new Headers(req.headers)\n requestHeaders.set('host', targetUrl.hostname)\n requestHeaders.set('authorization', `${process.env.CAPIBOX_API_KEY}`)\n\n if (req.nextUrl.pathname.includes('/realtime/')) {\n const ip = getClientIp({headers: Object.fromEntries(req.headers)})\n const {device, browser, os} = userAgent(req)\n requestHeaders.set('x-client-ip', ip)\n requestHeaders.set('x-os', `${os.name} / ${os.version}`)\n requestHeaders.set('x-browser', `${browser.name} / ${browser.version}`)\n requestHeaders.set('x-device', device.type ? device.type : '-')\n const anUuidV3Cookie = req.cookies.get('an_uuid_v3');\n if (anUuidV3Cookie) {\n requestHeaders.set('x-realtime', anUuidV3Cookie?.value)\n }\n }\n\n urlClone.protocol = targetUrl.protocol\n urlClone.hostname = targetUrl.hostname\n urlClone.port = targetUrl.port\n urlClone.pathname = urlClone.pathname.replace(/^\\/api-proxy/, '');\n\n return NextResponse.rewrite(urlClone, {\n headers: requestHeaders,\n })\n }\n\n // // mail\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_MAIL_SEND_TO_RECIPIENT) {\n // return NextResponse.json(await serverProxyPostRequest(req));\n // }\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_MAIL_SEND_TO_SUPPORT) {\n // return NextResponse.json(await serverProxyPostRequest(req));\n // }\n //\n // // session\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_SESSION_CREATE) {\n // return NextResponse.json(await serverProxyPostRequest(req));\n // }\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_SESSION_APPEND) {\n // const jsonData: dto.AppendSessionBrowserPublicDtoType = await req.json();\n // const proxyBody: dto.AppendSessionDtoType = {\n // email: jsonData.email,\n // language: jsonData.language,\n // currency: jsonData.currency,\n // };\n //\n // const res = await fetch(\n // req.nextUrl.pathname.replace(\n // endpoint.MAIN_ENDPOINT,\n // 'https://api.capibox.com'\n // ).replace('/append', `/${jsonData.uuid}`),\n // {\n // method: 'PUT',\n // body: JSON.stringify(proxyBody),\n // headers: serverProxyHeaders(),\n // }\n // )\n // return await res.json();\n // }\n //\n // // crm auth\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_CRM_AUTH_SIGN_IN) {\n // const res = await fetch(\n // 'https://auth.crm.apidata.app/api/sign-in',\n // {\n // method: 'POST',\n // body: JSON.stringify(await req.json()),\n // headers: serverProxyHeaders(),\n // }\n // )\n // const resJson: dto.SignInCrmResponseDtoType = await res.json();\n //\n // const result = NextResponse.json(resJson);\n // if (!!resJson.action && !!resJson.token && resJson.action === 'logged-in') {\n // result.cookies.set({\n // name: \"token\",\n // value: resJson.token,\n // maxAge: 60 * 60 * 24 * 30,\n // httpOnly: true,\n // });\n // }\n // return result;\n // }\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_CRM_AUTH_VERIFY) {\n // const tokenCookie = req.cookies.get('token')\n // if (!tokenCookie || !tokenCookie.value) {\n // return NextResponse.json({success: 0})\n // }\n //\n // const payload: dto.VerifyCrmUserDtoType = {\n // data: {\n // token: tokenCookie.value,\n // }\n // }\n // const res = await fetch(\n // 'https://auth.crm.apidata.app/api/check',\n // {\n // method: 'POST',\n // body: JSON.stringify(payload),\n // headers: serverProxyHeaders(),\n // }\n // )\n // const resJson: dto.VerifyCrmResponseDtoType = await res.json();\n //\n // const result = NextResponse.json(resJson);\n // if (!('id' in resJson && resJson.id > 0)) {\n // result.cookies.delete(\"token\");\n // }\n // return result;\n // }\n // if (req.nextUrl.pathname === endpoint.ENDPOINT_CRM_AUTH_SIGN_OUT) {\n // const res = NextResponse.json({success: 1});\n // res.cookies.delete(\"token\");\n // return res;\n // }\n}","\"use strict\";\n\nconst regexes = {\n ipv4: /^(?:(?:\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])\\.){3}(?:\\d|[1-9]\\d|1\\d{2}|2[0-4]\\d|25[0-5])$/,\n ipv6: /^((?=.*::)(?!.*::.+::)(::)?([\\dA-F]{1,4}:(:|\\b)|){5}|([\\dA-F]{1,4}:){6})((([\\dA-F]{1,4}((?!\\3)::|:\\b|$))|(?!\\2\\3)){2}|(((2[0-4]|1\\d|[1-9])?\\d|25[0-5])\\.?\\b){4})$/i\n};\n\nfunction not(func: any) {\n return function () {\n return !func.apply(null, Array.prototype.slice.call(arguments));\n };\n}\n\nfunction existy(value: any) {\n return value != null;\n}\n\nfunction ip(value: any) {\n return existy(value) && regexes.ipv4.test(value) || regexes.ipv6.test(value);\n}\n\nfunction object(value: any) {\n return Object(value) === value;\n}\n\nfunction string(value: any) {\n return Object.prototype.toString.call(value) === '[object String]';\n}\n\nconst is = {\n existy: existy,\n ip: ip,\n object: object,\n string: string,\n not: {\n existy: not(existy),\n ip: not(ip),\n object: not(object),\n string: not(string)\n }\n};\nexport default is;\n","import is from \"./is\";\n\nfunction getClientIpFromXForwardedFor(value: any) {\n if (!is.existy(value)) {\n return null;\n }\n\n const forwardedIps = value.split(',').map(function (e: string) {\n const ip = e.trim();\n\n if (ip.includes(':')) {\n const splitted = ip.split(':');\n if (splitted.length === 2) {\n return splitted[0];\n }\n }\n return ip;\n });\n\n for (let i = 0; i < forwardedIps.length; i++) {\n if (is.ip(forwardedIps[i])) {\n return forwardedIps[i];\n }\n }\n\n return null;\n}\n\nexport function getClientIp(req: {\n headers?: {\n [key: string]: string\n },\n connection?: {\n remoteAddress?: string,\n socket?: {\n remoteAddress?: string,\n },\n },\n socket?: {\n remoteAddress?: string,\n },\n info?: {\n remoteAddress?: string,\n },\n requestContext?: {\n identity?: {\n sourceIp?: string,\n }\n },\n}) {\n if (req.headers) {\n if (is.ip(req.headers['x-client-ip'])) {\n return req.headers['x-client-ip'];\n }\n\n const xForwardedFor = getClientIpFromXForwardedFor(req.headers['x-forwarded-for']);\n\n if (is.ip(req.headers['cf-connecting-ip'])) {\n return req.headers['cf-connecting-ip'];\n }\n\n if (is.ip(req.headers['fastly-client-ip'])) {\n return req.headers['fastly-client-ip'];\n }\n\n if (is.ip(req.headers['true-client-ip'])) {\n return req.headers['true-client-ip'];\n }\n\n if (is.ip(req.headers['x-real-ip'])) {\n return req.headers['x-real-ip'];\n }\n\n if (is.ip(req.headers['x-cluster-client-ip'])) {\n return req.headers['x-cluster-client-ip'];\n }\n\n if (is.ip(req.headers['x-forwarded'])) {\n return req.headers['x-forwarded'];\n }\n\n if (is.ip(req.headers['forwarded-for'])) {\n return req.headers['forwarded-for'];\n }\n\n if (is.ip(xForwardedFor)) {\n return xForwardedFor;\n }\n\n if (is.ip(req.headers.forwarded)) {\n return req.headers.forwarded;\n }\n\n if (is.ip(req.headers['x-appengine-user-ip'])) {\n return req.headers['x-appengine-user-ip'];\n }\n }\n\n if (is.existy(req.connection) && !!req.connection) {\n if (is.ip(req.connection.remoteAddress)) {\n return req.connection.remoteAddress;\n }\n\n if (is.existy(req.connection.socket) && !!req.connection.socket && !!req.connection.socket.remoteAddress && is.ip(req.connection.socket.remoteAddress)) {\n return req.connection.socket.remoteAddress;\n }\n }\n\n if (is.existy(req.socket) && !!req.socket && !!req.socket.remoteAddress && is.ip(req.socket.remoteAddress)) {\n return req.socket.remoteAddress;\n }\n\n if (is.existy(req.info) && !!req.info && !!req.info.remoteAddress && is.ip(req.info.remoteAddress)) {\n return req.info.remoteAddress;\n }\n\n if (is.existy(req.requestContext) && !!req.requestContext && is.existy(req.requestContext.identity) && !!req.requestContext.identity && !!req.requestContext.identity.sourceIp && is.ip(req.requestContext.identity.sourceIp)) {\n return req.requestContext.identity.sourceIp;\n }\n\n if (req.headers) {\n if (is.ip(req.headers['Cf-Pseudo-IPv4'])) {\n return req.headers['Cf-Pseudo-IPv4'];\n }\n }\n\n return \"127.0.0.2\";\n}\n\n","// import {dto, endpoint} from \"@capibox/bridge-interface\";\n// import {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n\nexport const create = async (): Promise<void> => {\n // const res = await fetch(\n // endpoint.ENDPOINT_SESSION_CREATE,\n // fetchJsonPostOptions(data)\n // )\n // return await res.json();\n}","// import {dto, endpoint} from \"@capibox/bridge-interface\";\n// import {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n//\n// export const signIn = async (data: dto.SignInCrmUserDtoType): Promise<dto.SignInCrmResponseDtoType> => {\n// const res = await fetch(\n// endpoint.ENDPOINT_CRM_AUTH_SIGN_IN,\n// fetchJsonPostOptions(data)\n// )\n// return await res.json();\n// }\nexport const signIn = async (): Promise<void> => {}","// import {dto, endpoint} from \"@capibox/bridge-interface\";\n// import {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n//\n// export const signOut = async (): Promise<{ success: 1 }> => {\n// const res = await fetch(\n// endpoint.ENDPOINT_CRM_AUTH_SIGN_OUT,\n// fetchJsonPostOptions({})\n// )\n// return await res.json();\n// }\n\nexport const signOut = async (): Promise<void> => {}","// import {dto, endpoint} from \"@capibox/bridge-interface\";\n// import {fetchJsonPostOptions} from \"../_utils/browser-fetch-utils\";\n//\n// export const verify = async (): Promise<dto.VerifyCrmResponseDtoType> => {\n// const res = await fetch(\n// endpoint.ENDPOINT_CRM_AUTH_VERIFY,\n// fetchJsonPostOptions({})\n// )\n// return await res.json();\n// }\n\nexport const verify = async (): Promise<void> => {}","import {useParams} from 'next/navigation'\n\nexport type ParamsLandingPage = {\n landing?: string\n checkout?: string\n}\nexport type ParamsLandingPageResponse = {\n landing: string\n checkout: string\n angle: string\n version: string\n path: {\n root: string\n rootPretty: string\n }\n}\n\nexport const useParamsLandingPage = (): ParamsLandingPageResponse => {\n const params = useParams<ParamsLandingPage>();\n\n const angle = (params.landing ?? 'main').toLowerCase()\n const version = (params.checkout ?? 'a').toLowerCase()\n\n return {\n landing: angle,\n checkout: version,\n angle,\n version,\n path: {\n root: `/${angle}/${version}`,\n rootPretty: angle === 'main' && version === 'a' ? '' : `/${angle}/${version}`\n }\n }\n}","import {sendToRecipient} from \"./browser/mail/send-to-recipient\";\nimport {sendToSupport} from \"./browser/mail/send-to-support\";\nimport {append} from \"./browser/session/append\";\nimport {middleware} from \"./server/middleware\";\nimport {create} from \"./browser/session/create\";\nimport {signIn} from \"./browser/crm-auth/sign-in\";\nimport {signOut} from \"./browser/crm-auth/sign-out\";\nimport {verify} from \"./browser/crm-auth/veirfy\";\nimport {useParamsLandingPage} from \"./browser/hooks/useParamsLandingPage\";\n\nconst browser = {\n mail: {\n sendToRecipient,\n sendToSupport,\n },\n session: {\n append,\n create,\n },\n crmAuth: {\n signIn,\n signOut,\n verify,\n },\n hooks: {\n useParamsLandingPage\n }\n}\n\nconst server = {\n middleware\n}\n\nexport {\n browser,\n server\n}\n// v.0.0.12"],"mappings":"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","names":["ip","ip","browser"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@capibox/bridge-nextjs-client",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.13",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"module": "./dist/index.mjs",
|
|
@@ -16,14 +16,16 @@
|
|
|
16
16
|
"author": "",
|
|
17
17
|
"license": "ISC",
|
|
18
18
|
"devDependencies": {
|
|
19
|
+
"openapi-typescript": "^7.8.0",
|
|
19
20
|
"ts-node": "^10.9.2",
|
|
20
21
|
"tsup": "^8.0.2",
|
|
21
|
-
"typescript": "^5.
|
|
22
|
+
"typescript": "^5.8.3"
|
|
22
23
|
},
|
|
23
24
|
"dependencies": {
|
|
24
|
-
"@capibox/bridge-interface": "^0.0.38",
|
|
25
25
|
"@nestjs/swagger": "^11.2.0",
|
|
26
26
|
"class-validator": "^0.14.2",
|
|
27
|
+
"openapi-fetch": "^0.14.0",
|
|
28
|
+
"openapi-react-query": "^0.5.0",
|
|
27
29
|
"zod": "^3.24.1"
|
|
28
30
|
},
|
|
29
31
|
"peerDependencies": {
|