@flink-app/generic-auth-plugin 2.0.0-alpha.56 → 2.0.0-alpha.57
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/.flink/generatedAgents.ts +1 -1
- package/.flink/generatedHandlers.ts +1 -1
- package/.flink/generatedJobs.ts +1 -1
- package/.flink/generatedRepos.ts +1 -1
- package/.flink/generatedTools.ts +1 -1
- package/.flink/start.ts +1 -1
- package/CHANGELOG.md +20 -0
- package/dist/.flink/generatedAgents.js +13 -6
- package/dist/.flink/generatedAgents.js.map +1 -0
- package/dist/.flink/generatedHandlers.js +13 -6
- package/dist/.flink/generatedHandlers.js.map +1 -0
- package/dist/.flink/generatedJobs.js +13 -6
- package/dist/.flink/generatedJobs.js.map +1 -0
- package/dist/.flink/generatedRepos.js +13 -6
- package/dist/.flink/generatedRepos.js.map +1 -0
- package/dist/.flink/generatedTools.js +13 -6
- package/dist/.flink/generatedTools.js.map +1 -0
- package/dist/.flink/schema-manifest.json +588 -0
- package/dist/.flink/schemas/schemas.js +1 -1
- package/dist/.flink/start.js +12 -3
- package/dist/.flink/start.js.map +1 -0
- package/dist/.tsbuildinfo +1 -0
- package/dist/src/coreFunctions.js +356 -412
- package/dist/src/coreFunctions.js.map +1 -0
- package/dist/src/genericAuthContext.js +3 -1
- package/dist/src/genericAuthContext.js.map +1 -0
- package/dist/src/genericAuthPluginOptions.js +3 -1
- package/dist/src/genericAuthPluginOptions.js.map +1 -0
- package/dist/src/handlers/Management/DeleteUserByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/DeleteUserByUserid.js +21 -60
- package/dist/src/handlers/Management/DeleteUserByUserid.js.map +1 -0
- package/dist/src/handlers/Management/GetSchema.d.ts +1 -1
- package/dist/src/handlers/Management/GetSchema.js +16 -50
- package/dist/src/handlers/Management/GetSchema.js.map +1 -0
- package/dist/src/handlers/Management/GetUser.d.ts +1 -1
- package/dist/src/handlers/Management/GetUser.js +25 -59
- package/dist/src/handlers/Management/GetUser.js.map +1 -0
- package/dist/src/handlers/Management/GetUserByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/GetUserByUserid.js +60 -71
- package/dist/src/handlers/Management/GetUserByUserid.js.map +1 -0
- package/dist/src/handlers/Management/GetUserViewByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/GetUserViewByUserid.js +35 -74
- package/dist/src/handlers/Management/GetUserViewByUserid.js.map +1 -0
- package/dist/src/handlers/Management/PutUserPasswordByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/PutUserPasswordByUserid.js +37 -85
- package/dist/src/handlers/Management/PutUserPasswordByUserid.js.map +1 -0
- package/dist/src/handlers/Management/PutUserProfileByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/PutUserProfileByUserid.js +27 -70
- package/dist/src/handlers/Management/PutUserProfileByUserid.js.map +1 -0
- package/dist/src/handlers/Management/PutUserProfileByUseridAppend.d.ts +1 -1
- package/dist/src/handlers/Management/PutUserProfileByUseridAppend.js +53 -76
- package/dist/src/handlers/Management/PutUserProfileByUseridAppend.js.map +1 -0
- package/dist/src/handlers/Management/PutUserRolesByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/PutUserRolesByUserid.js +24 -63
- package/dist/src/handlers/Management/PutUserRolesByUserid.js.map +1 -0
- package/dist/src/handlers/Management/PutUserUsernameByUserid.d.ts +1 -1
- package/dist/src/handlers/Management/PutUserUsernameByUserid.js +31 -72
- package/dist/src/handlers/Management/PutUserUsernameByUserid.js.map +1 -0
- package/dist/src/handlers/UserCreate.d.ts +1 -1
- package/dist/src/handlers/UserCreate.js +44 -84
- package/dist/src/handlers/UserCreate.js.map +1 -0
- package/dist/src/handlers/UserLogin.d.ts +1 -1
- package/dist/src/handlers/UserLogin.js +45 -88
- package/dist/src/handlers/UserLogin.js.map +1 -0
- package/dist/src/handlers/UserLoginByToken.d.ts +1 -1
- package/dist/src/handlers/UserLoginByToken.js +24 -63
- package/dist/src/handlers/UserLoginByToken.js.map +1 -0
- package/dist/src/handlers/UserPasswordPut.d.ts +1 -1
- package/dist/src/handlers/UserPasswordPut.js +24 -60
- package/dist/src/handlers/UserPasswordPut.js.map +1 -0
- package/dist/src/handlers/UserPasswordResetComplete.d.ts +1 -1
- package/dist/src/handlers/UserPasswordResetComplete.js +30 -66
- package/dist/src/handlers/UserPasswordResetComplete.js.map +1 -0
- package/dist/src/handlers/UserPasswordResetForm.d.ts +1 -1
- package/dist/src/handlers/UserPasswordResetForm.js +155 -110
- package/dist/src/handlers/UserPasswordResetForm.js.map +1 -0
- package/dist/src/handlers/UserPasswordResetStart.d.ts +1 -1
- package/dist/src/handlers/UserPasswordResetStart.js +66 -95
- package/dist/src/handlers/UserPasswordResetStart.js.map +1 -0
- package/dist/src/handlers/UserProfileGet.d.ts +1 -1
- package/dist/src/handlers/UserProfileGet.js +21 -60
- package/dist/src/handlers/UserProfileGet.js.map +1 -0
- package/dist/src/handlers/UserProfilePut.d.ts +1 -1
- package/dist/src/handlers/UserProfilePut.js +55 -81
- package/dist/src/handlers/UserProfilePut.js.map +1 -0
- package/dist/src/handlers/UserPushRegisterToken.d.ts +1 -1
- package/dist/src/handlers/UserPushRegisterToken.js +119 -118
- package/dist/src/handlers/UserPushRegisterToken.js.map +1 -0
- package/dist/src/handlers/UserPushRemoveToken.d.ts +1 -1
- package/dist/src/handlers/UserPushRemoveToken.js +26 -63
- package/dist/src/handlers/UserPushRemoveToken.js.map +1 -0
- package/dist/src/handlers/UserToken.d.ts +1 -1
- package/dist/src/handlers/UserToken.js +29 -63
- package/dist/src/handlers/UserToken.js.map +1 -0
- package/dist/src/index.js +133 -50
- package/dist/src/index.js.map +1 -0
- package/dist/src/init.js +160 -101
- package/dist/src/init.js.map +1 -0
- package/dist/src/management.js +109 -86
- package/dist/src/management.js.map +1 -0
- package/dist/src/schemas/Management/DeleteUserByUseridReq.js +3 -1
- package/dist/src/schemas/Management/DeleteUserByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/DeleteUserByUseridRes.js +3 -1
- package/dist/src/schemas/Management/DeleteUserByUseridRes.js.map +1 -0
- package/dist/src/schemas/Management/GetUserByUseridReq.js +3 -1
- package/dist/src/schemas/Management/GetUserByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/GetUserByUseridRes.js +3 -1
- package/dist/src/schemas/Management/GetUserByUseridRes.js.map +1 -0
- package/dist/src/schemas/Management/GetUserReq.js +3 -1
- package/dist/src/schemas/Management/GetUserReq.js.map +1 -0
- package/dist/src/schemas/Management/GetUserRes.js +3 -1
- package/dist/src/schemas/Management/GetUserRes.js.map +1 -0
- package/dist/src/schemas/Management/GetUserViewByUseridReq.js +3 -1
- package/dist/src/schemas/Management/GetUserViewByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/GetUserViewByUseridRes.js +3 -1
- package/dist/src/schemas/Management/GetUserViewByUseridRes.js.map +1 -0
- package/dist/src/schemas/Management/PutUserPasswordByUseridReq.js +3 -1
- package/dist/src/schemas/Management/PutUserPasswordByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/PutUserPasswordByUseridRes.js +3 -1
- package/dist/src/schemas/Management/PutUserPasswordByUseridRes.js.map +1 -0
- package/dist/src/schemas/Management/PutUserProfileByUseridReq.js +3 -1
- package/dist/src/schemas/Management/PutUserProfileByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/PutUserProfileByUseridRes.js +3 -1
- package/dist/src/schemas/Management/PutUserProfileByUseridRes.js.map +1 -0
- package/dist/src/schemas/Management/PutUserRolesByUseridReq.js +3 -1
- package/dist/src/schemas/Management/PutUserRolesByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/PutUserRolesByUseridRes.js +3 -1
- package/dist/src/schemas/Management/PutUserRolesByUseridRes.js.map +1 -0
- package/dist/src/schemas/Management/PutUserUsernameByUseridReq.js +3 -1
- package/dist/src/schemas/Management/PutUserUsernameByUseridReq.js.map +1 -0
- package/dist/src/schemas/Management/PutUserUsernameByUseridRes.js +3 -1
- package/dist/src/schemas/Management/PutUserUsernameByUseridRes.js.map +1 -0
- package/dist/src/schemas/PushNotificationToken.js +3 -1
- package/dist/src/schemas/PushNotificationToken.js.map +1 -0
- package/dist/src/schemas/PushNotificationTokenRes.js +3 -1
- package/dist/src/schemas/PushNotificationTokenRes.js.map +1 -0
- package/dist/src/schemas/User.js +3 -1
- package/dist/src/schemas/User.js.map +1 -0
- package/dist/src/schemas/UserCreateReq.js +3 -1
- package/dist/src/schemas/UserCreateReq.js.map +1 -0
- package/dist/src/schemas/UserCreateRes.js +3 -1
- package/dist/src/schemas/UserCreateRes.js.map +1 -0
- package/dist/src/schemas/UserLoginByTokenReq.js +3 -1
- package/dist/src/schemas/UserLoginByTokenReq.js.map +1 -0
- package/dist/src/schemas/UserLoginReq.js +3 -1
- package/dist/src/schemas/UserLoginReq.js.map +1 -0
- package/dist/src/schemas/UserLoginRes.js +3 -1
- package/dist/src/schemas/UserLoginRes.js.map +1 -0
- package/dist/src/schemas/UserPasswordChangeReq.js +3 -1
- package/dist/src/schemas/UserPasswordChangeReq.js.map +1 -0
- package/dist/src/schemas/UserPasswordChangeRes.js +3 -1
- package/dist/src/schemas/UserPasswordChangeRes.js.map +1 -0
- package/dist/src/schemas/UserPasswordResetCompleteReq.js +3 -1
- package/dist/src/schemas/UserPasswordResetCompleteReq.js.map +1 -0
- package/dist/src/schemas/UserPasswordResetCompleteRes.js +3 -1
- package/dist/src/schemas/UserPasswordResetCompleteRes.js.map +1 -0
- package/dist/src/schemas/UserPasswordResetSettings.js +3 -1
- package/dist/src/schemas/UserPasswordResetSettings.js.map +1 -0
- package/dist/src/schemas/UserPasswordResetStartReq.js +3 -1
- package/dist/src/schemas/UserPasswordResetStartReq.js.map +1 -0
- package/dist/src/schemas/UserPasswordResetStartRes.js +3 -1
- package/dist/src/schemas/UserPasswordResetStartRes.js.map +1 -0
- package/dist/src/schemas/UserPasswordResetStartResPublic.js +3 -1
- package/dist/src/schemas/UserPasswordResetStartResPublic.js.map +1 -0
- package/dist/src/schemas/UserProfile.js +3 -1
- package/dist/src/schemas/UserProfile.js.map +1 -0
- package/dist/src/schemas/UserTokenRes.js +3 -1
- package/dist/src/schemas/UserTokenRes.js.map +1 -0
- package/package.json +7 -7
- package/src/handlers/Management/DeleteUserByUserid.ts +10 -14
- package/src/handlers/Management/GetSchema.ts +6 -12
- package/src/handlers/Management/GetUser.ts +11 -15
- package/src/handlers/Management/GetUserByUserid.ts +13 -23
- package/src/handlers/Management/PutUserPasswordByUserid.ts +39 -45
- package/src/handlers/Management/PutUserProfileByUserid.ts +21 -27
- package/src/handlers/Management/PutUserProfileByUseridAppend.ts +22 -28
- package/src/handlers/Management/PutUserRolesByUserid.ts +17 -23
- package/src/handlers/Management/PutUserUsernameByUserid.ts +24 -31
- package/src/handlers/UserLoginByToken.ts +20 -27
- package/src/handlers/UserPasswordPut.ts +17 -24
- package/src/handlers/UserPasswordResetComplete.ts +31 -40
- package/src/handlers/UserPasswordResetForm.ts +25 -29
- package/src/handlers/UserPasswordResetStart.ts +11 -3
- package/src/handlers/UserProfileGet.ts +11 -14
- package/src/handlers/UserPushRemoveToken.ts +12 -18
- package/src/handlers/UserToken.ts +13 -24
- package/src/init.ts +23 -1
- package/.flink/schemas/schemas.ts +0 -1
|
@@ -1,124 +1,125 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return _default;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _flink = require("@flink-app/flink");
|
|
12
|
+
function _define_property(obj, key, value) {
|
|
13
|
+
if (key in obj) {
|
|
14
|
+
Object.defineProperty(obj, key, {
|
|
15
|
+
value: value,
|
|
16
|
+
enumerable: true,
|
|
17
|
+
configurable: true,
|
|
18
|
+
writable: true
|
|
19
|
+
});
|
|
20
|
+
} else {
|
|
21
|
+
obj[key] = value;
|
|
22
|
+
}
|
|
23
|
+
return obj;
|
|
24
|
+
}
|
|
25
|
+
function _object_spread(target) {
|
|
26
|
+
for(var i = 1; i < arguments.length; i++){
|
|
27
|
+
var source = arguments[i] != null ? arguments[i] : {};
|
|
28
|
+
var ownKeys = Object.keys(source);
|
|
29
|
+
if (typeof Object.getOwnPropertySymbols === "function") {
|
|
30
|
+
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
31
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
32
|
+
}));
|
|
8
33
|
}
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
34
|
+
ownKeys.forEach(function(key) {
|
|
35
|
+
_define_property(target, key, source[key]);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
return target;
|
|
39
|
+
}
|
|
40
|
+
function ownKeys(object, enumerableOnly) {
|
|
41
|
+
var keys = Object.keys(object);
|
|
42
|
+
if (Object.getOwnPropertySymbols) {
|
|
43
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
44
|
+
if (enumerableOnly) {
|
|
45
|
+
symbols = symbols.filter(function(sym) {
|
|
46
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
keys.push.apply(keys, symbols);
|
|
50
|
+
}
|
|
51
|
+
return keys;
|
|
52
|
+
}
|
|
53
|
+
function _object_spread_props(target, source) {
|
|
54
|
+
source = source != null ? source : {};
|
|
55
|
+
if (Object.getOwnPropertyDescriptors) {
|
|
56
|
+
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
57
|
+
} else {
|
|
58
|
+
ownKeys(Object(source)).forEach(function(key) {
|
|
59
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
return target;
|
|
63
|
+
}
|
|
64
|
+
const postUserPushRegisterTokenHandler = async ({ ctx, req, origin })=>{
|
|
65
|
+
var _pluginOptions_allowMultipleDevices;
|
|
66
|
+
const pluginName = origin || "genericAuthPlugin";
|
|
67
|
+
const pluginOptions = ctx.plugins[pluginName];
|
|
68
|
+
const repo = ctx.repos[pluginOptions.repoName];
|
|
69
|
+
const deregisterOtherDevices = pluginOptions.deregisterOtherDevices || false;
|
|
70
|
+
const allowMultipleDevices = (_pluginOptions_allowMultipleDevices = pluginOptions.allowMultipleDevices) !== null && _pluginOptions_allowMultipleDevices !== void 0 ? _pluginOptions_allowMultipleDevices : true;
|
|
71
|
+
const user = await repo.getById(req.user._id);
|
|
72
|
+
if (user == null) {
|
|
73
|
+
return (0, _flink.notFound)("User not found");
|
|
74
|
+
}
|
|
75
|
+
let exToken = user.pushNotificationTokens.find((t)=>t.deviceId == req.body.deviceId);
|
|
76
|
+
if (exToken != null) {
|
|
77
|
+
exToken.token = req.body.token;
|
|
78
|
+
exToken.type = req.body.type || "firebase";
|
|
79
|
+
} else {
|
|
80
|
+
user.pushNotificationTokens.push(_object_spread_props(_object_spread({}, req.body), {
|
|
81
|
+
type: req.body.type || "firebase"
|
|
82
|
+
}));
|
|
83
|
+
}
|
|
84
|
+
if (!allowMultipleDevices) {
|
|
85
|
+
// Filter out all other devices except the newly registered one
|
|
86
|
+
user.pushNotificationTokens = user.pushNotificationTokens.filter((t)=>t.deviceId === req.body.deviceId);
|
|
87
|
+
}
|
|
88
|
+
await repo.updateOne(user._id, {
|
|
89
|
+
pushNotificationTokens: user.pushNotificationTokens
|
|
20
90
|
});
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
91
|
+
if (deregisterOtherDevices) {
|
|
92
|
+
const otherRegistrations = await repo.findAll({
|
|
93
|
+
$or: [
|
|
94
|
+
{
|
|
95
|
+
"pushNotificationTokens.deviceId": req.body.deviceId
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
"pushNotificationTokens.token": req.body.token
|
|
99
|
+
}
|
|
100
|
+
],
|
|
101
|
+
_id: {
|
|
102
|
+
$ne: repo.buildId(user._id)
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
_flink.log.debug(`Found ${otherRegistrations.length} other registrations for device ${req.body.deviceId} or token ${req.body.token}`);
|
|
106
|
+
for (let other of otherRegistrations){
|
|
107
|
+
try {
|
|
108
|
+
let lengthBefore = other.pushNotificationTokens.length;
|
|
109
|
+
other.pushNotificationTokens = other.pushNotificationTokens.filter((t)=>t.deviceId !== req.body.deviceId && t.token !== req.body.token);
|
|
110
|
+
_flink.log.debug(`Deregistering ${lengthBefore - other.pushNotificationTokens.length} devices for user ${other._id} as other user ${user._id} claimed this device`);
|
|
111
|
+
await repo.updateOne(other._id, {
|
|
112
|
+
pushNotificationTokens: other.pushNotificationTokens
|
|
113
|
+
});
|
|
114
|
+
} catch (e) {
|
|
115
|
+
console.error("Error deregistering other devices", e);
|
|
43
116
|
}
|
|
44
|
-
|
|
45
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
46
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
117
|
+
}
|
|
47
118
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
var flink_1 = require("@flink-app/flink");
|
|
52
|
-
var postUserPushRegisterTokenHandler = function (_a) { return __awaiter(void 0, [_a], void 0, function (_b) {
|
|
53
|
-
var pluginName, pluginOptions, repo, deregisterOtherDevices, allowMultipleDevices, user, exToken, otherRegistrations, _i, otherRegistrations_1, other, lengthBefore, e_1;
|
|
54
|
-
var _c;
|
|
55
|
-
var ctx = _b.ctx, req = _b.req, origin = _b.origin;
|
|
56
|
-
return __generator(this, function (_d) {
|
|
57
|
-
switch (_d.label) {
|
|
58
|
-
case 0:
|
|
59
|
-
pluginName = origin || "genericAuthPlugin";
|
|
60
|
-
pluginOptions = ctx.plugins[pluginName];
|
|
61
|
-
repo = ctx.repos[pluginOptions.repoName];
|
|
62
|
-
deregisterOtherDevices = pluginOptions.deregisterOtherDevices || false;
|
|
63
|
-
allowMultipleDevices = (_c = pluginOptions.allowMultipleDevices) !== null && _c !== void 0 ? _c : true;
|
|
64
|
-
return [4 /*yield*/, repo.getById(req.user._id)];
|
|
65
|
-
case 1:
|
|
66
|
-
user = _d.sent();
|
|
67
|
-
if (user == null) {
|
|
68
|
-
return [2 /*return*/, (0, flink_1.notFound)("User not found")];
|
|
69
|
-
}
|
|
70
|
-
exToken = user.pushNotificationTokens.find(function (t) { return t.deviceId == req.body.deviceId; });
|
|
71
|
-
if (exToken != null) {
|
|
72
|
-
exToken.token = req.body.token;
|
|
73
|
-
exToken.type = req.body.type || "firebase";
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
user.pushNotificationTokens.push(__assign(__assign({}, req.body), { type: req.body.type || "firebase" }));
|
|
77
|
-
}
|
|
78
|
-
if (!allowMultipleDevices) {
|
|
79
|
-
// Filter out all other devices except the newly registered one
|
|
80
|
-
user.pushNotificationTokens = user.pushNotificationTokens.filter(function (t) { return t.deviceId === req.body.deviceId; });
|
|
81
|
-
}
|
|
82
|
-
return [4 /*yield*/, repo.updateOne(user._id, {
|
|
83
|
-
pushNotificationTokens: user.pushNotificationTokens,
|
|
84
|
-
})];
|
|
85
|
-
case 2:
|
|
86
|
-
_d.sent();
|
|
87
|
-
if (!deregisterOtherDevices) return [3 /*break*/, 9];
|
|
88
|
-
return [4 /*yield*/, repo.findAll({
|
|
89
|
-
$or: [{ "pushNotificationTokens.deviceId": req.body.deviceId }, { "pushNotificationTokens.token": req.body.token }],
|
|
90
|
-
_id: { $ne: repo.buildId(user._id) },
|
|
91
|
-
})];
|
|
92
|
-
case 3:
|
|
93
|
-
otherRegistrations = _d.sent();
|
|
94
|
-
flink_1.log.debug("Found ".concat(otherRegistrations.length, " other registrations for device ").concat(req.body.deviceId, " or token ").concat(req.body.token));
|
|
95
|
-
_i = 0, otherRegistrations_1 = otherRegistrations;
|
|
96
|
-
_d.label = 4;
|
|
97
|
-
case 4:
|
|
98
|
-
if (!(_i < otherRegistrations_1.length)) return [3 /*break*/, 9];
|
|
99
|
-
other = otherRegistrations_1[_i];
|
|
100
|
-
_d.label = 5;
|
|
101
|
-
case 5:
|
|
102
|
-
_d.trys.push([5, 7, , 8]);
|
|
103
|
-
lengthBefore = other.pushNotificationTokens.length;
|
|
104
|
-
other.pushNotificationTokens = other.pushNotificationTokens.filter(function (t) { return t.deviceId !== req.body.deviceId && t.token !== req.body.token; });
|
|
105
|
-
flink_1.log.debug("Deregistering ".concat(lengthBefore - other.pushNotificationTokens.length, " devices for user ").concat(other._id, " as other user ").concat(user._id, " claimed this device"));
|
|
106
|
-
return [4 /*yield*/, repo.updateOne(other._id, {
|
|
107
|
-
pushNotificationTokens: other.pushNotificationTokens,
|
|
108
|
-
})];
|
|
109
|
-
case 6:
|
|
110
|
-
_d.sent();
|
|
111
|
-
return [3 /*break*/, 8];
|
|
112
|
-
case 7:
|
|
113
|
-
e_1 = _d.sent();
|
|
114
|
-
console.error("Error deregistering other devices", e_1);
|
|
115
|
-
return [3 /*break*/, 8];
|
|
116
|
-
case 8:
|
|
117
|
-
_i++;
|
|
118
|
-
return [3 /*break*/, 4];
|
|
119
|
-
case 9: return [2 /*return*/, { data: { status: "success" } }];
|
|
119
|
+
return {
|
|
120
|
+
data: {
|
|
121
|
+
status: "success"
|
|
120
122
|
}
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
exports.__assumedHttpMethod = "", exports.__file = "UserPushRegisterToken.ts", exports.__query = [], exports.__params = [];
|
|
123
|
+
};
|
|
124
|
+
};
|
|
125
|
+
const _default = postUserPushRegisterTokenHandler;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/joel/projects/flink/flink-framework/packages/generic-auth-plugin/src/handlers/UserPushRegisterToken.ts"],"sourcesContent":["import { FlinkContext, Handler, log, notFound } from \"@flink-app/flink\";\nimport { genericAuthContext } from \"../genericAuthContext\";\nimport { PushNotificationToken } from \"../schemas/PushNotificationToken\";\nimport { PushNotificatioNTokenRes } from \"../schemas/PushNotificationTokenRes\";\nimport { User } from \"../schemas/User\";\nimport { GenericAuthPluginOptions } from \"../genericAuthPluginOptions\";\n\nconst postUserPushRegisterTokenHandler: Handler<FlinkContext<genericAuthContext>, PushNotificationToken, PushNotificatioNTokenRes> = async ({\n ctx,\n req,\n origin,\n}) => {\n const pluginName = origin || \"genericAuthPlugin\";\n const pluginOptions: GenericAuthPluginOptions = (ctx.plugins as any)[pluginName];\n const repo = ctx.repos[pluginOptions.repoName];\n const deregisterOtherDevices = pluginOptions.deregisterOtherDevices || false;\n const allowMultipleDevices = pluginOptions.allowMultipleDevices ?? true;\n\n const user = <User>await repo.getById(req.user._id);\n\n if (user == null) {\n return notFound(\"User not found\");\n }\n\n let exToken = user.pushNotificationTokens.find((t) => t.deviceId == req.body.deviceId);\n\n if (exToken != null) {\n exToken.token = req.body.token;\n exToken.type = req.body.type || \"firebase\";\n } else {\n user.pushNotificationTokens.push({ ...req.body, type: req.body.type || \"firebase\" });\n }\n\n if (!allowMultipleDevices) {\n // Filter out all other devices except the newly registered one\n user.pushNotificationTokens = user.pushNotificationTokens.filter((t) => t.deviceId === req.body.deviceId);\n }\n\n await repo.updateOne(user._id, {\n pushNotificationTokens: user.pushNotificationTokens,\n });\n\n if (deregisterOtherDevices) {\n const otherRegistrations = <User[]>await repo.findAll({\n $or: [{ \"pushNotificationTokens.deviceId\": req.body.deviceId }, { \"pushNotificationTokens.token\": req.body.token }],\n _id: { $ne: repo.buildId(user._id) },\n });\n\n log.debug(`Found ${otherRegistrations.length} other registrations for device ${req.body.deviceId} or token ${req.body.token}`);\n\n for (let other of otherRegistrations) {\n try {\n let lengthBefore = other.pushNotificationTokens.length;\n\n other.pushNotificationTokens = other.pushNotificationTokens.filter((t) => t.deviceId !== req.body.deviceId && t.token !== req.body.token);\n\n log.debug(\n `Deregistering ${lengthBefore - other.pushNotificationTokens.length} devices for user ${other._id} as other user ${\n user._id\n } claimed this device`\n );\n\n await repo.updateOne(other._id, {\n pushNotificationTokens: other.pushNotificationTokens,\n });\n } catch (e) {\n console.error(\"Error deregistering other devices\", e);\n }\n }\n }\n\n return { data: { status: \"success\" } };\n};\n\nexport default postUserPushRegisterTokenHandler;\n"],"names":["postUserPushRegisterTokenHandler","ctx","req","origin","pluginOptions","pluginName","plugins","repo","repos","repoName","deregisterOtherDevices","allowMultipleDevices","user","getById","_id","notFound","exToken","pushNotificationTokens","find","t","deviceId","body","token","type","push","filter","updateOne","otherRegistrations","findAll","$or","$ne","buildId","log","debug","length","other","lengthBefore","e","console","error","data","status"],"mappings":";;;;+BA0EA;;;eAAA;;;uBA1EqD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOrD,MAAMA,mCAA+H,OAAO,EACxIC,GAAG,EACHC,GAAG,EACHC,MAAM,EACT;QAKgCC;IAJ7B,MAAMC,aAAaF,UAAU;IAC7B,MAAMC,gBAA0C,AAACH,IAAIK,OAAO,AAAQ,CAACD,WAAW;IAChF,MAAME,OAAON,IAAIO,KAAK,CAACJ,cAAcK,QAAQ,CAAC;IAC9C,MAAMC,yBAAyBN,cAAcM,sBAAsB,IAAI;IACvE,MAAMC,wBAAuBP,sCAAAA,cAAcO,oBAAoB,cAAlCP,iDAAAA,sCAAsC;IAEnE,MAAMQ,OAAa,MAAML,KAAKM,OAAO,CAACX,IAAIU,IAAI,CAACE,GAAG;IAElD,IAAIF,QAAQ,MAAM;QACd,OAAOG,IAAAA,eAAQ,EAAC;IACpB;IAEA,IAAIC,UAAUJ,KAAKK,sBAAsB,CAACC,IAAI,CAAC,CAACC,IAAMA,EAAEC,QAAQ,IAAIlB,IAAImB,IAAI,CAACD,QAAQ;IAErF,IAAIJ,WAAW,MAAM;QACjBA,QAAQM,KAAK,GAAGpB,IAAImB,IAAI,CAACC,KAAK;QAC9BN,QAAQO,IAAI,GAAGrB,IAAImB,IAAI,CAACE,IAAI,IAAI;IACpC,OAAO;QACHX,KAAKK,sBAAsB,CAACO,IAAI,CAAC,wCAAKtB,IAAImB,IAAI;YAAEE,MAAMrB,IAAImB,IAAI,CAACE,IAAI,IAAI;;IAC3E;IAEA,IAAI,CAACZ,sBAAsB;QACvB,+DAA+D;QAC/DC,KAAKK,sBAAsB,GAAGL,KAAKK,sBAAsB,CAACQ,MAAM,CAAC,CAACN,IAAMA,EAAEC,QAAQ,KAAKlB,IAAImB,IAAI,CAACD,QAAQ;IAC5G;IAEA,MAAMb,KAAKmB,SAAS,CAACd,KAAKE,GAAG,EAAE;QAC3BG,wBAAwBL,KAAKK,sBAAsB;IACvD;IAEA,IAAIP,wBAAwB;QACxB,MAAMiB,qBAA6B,MAAMpB,KAAKqB,OAAO,CAAC;YAClDC,KAAK;gBAAC;oBAAE,mCAAmC3B,IAAImB,IAAI,CAACD,QAAQ;gBAAC;gBAAG;oBAAE,gCAAgClB,IAAImB,IAAI,CAACC,KAAK;gBAAC;aAAE;YACnHR,KAAK;gBAAEgB,KAAKvB,KAAKwB,OAAO,CAACnB,KAAKE,GAAG;YAAE;QACvC;QAEAkB,UAAG,CAACC,KAAK,CAAC,CAAC,MAAM,EAAEN,mBAAmBO,MAAM,CAAC,gCAAgC,EAAEhC,IAAImB,IAAI,CAACD,QAAQ,CAAC,UAAU,EAAElB,IAAImB,IAAI,CAACC,KAAK,EAAE;QAE7H,KAAK,IAAIa,SAASR,mBAAoB;YAClC,IAAI;gBACA,IAAIS,eAAeD,MAAMlB,sBAAsB,CAACiB,MAAM;gBAEtDC,MAAMlB,sBAAsB,GAAGkB,MAAMlB,sBAAsB,CAACQ,MAAM,CAAC,CAACN,IAAMA,EAAEC,QAAQ,KAAKlB,IAAImB,IAAI,CAACD,QAAQ,IAAID,EAAEG,KAAK,KAAKpB,IAAImB,IAAI,CAACC,KAAK;gBAExIU,UAAG,CAACC,KAAK,CACL,CAAC,cAAc,EAAEG,eAAeD,MAAMlB,sBAAsB,CAACiB,MAAM,CAAC,kBAAkB,EAAEC,MAAMrB,GAAG,CAAC,eAAe,EAC7GF,KAAKE,GAAG,CACX,oBAAoB,CAAC;gBAG1B,MAAMP,KAAKmB,SAAS,CAACS,MAAMrB,GAAG,EAAE;oBAC5BG,wBAAwBkB,MAAMlB,sBAAsB;gBACxD;YACJ,EAAE,OAAOoB,GAAG;gBACRC,QAAQC,KAAK,CAAC,qCAAqCF;YACvD;QACJ;IACJ;IAEA,OAAO;QAAEG,MAAM;YAAEC,QAAQ;QAAU;IAAE;AACzC;MAEA,WAAezC"}
|
|
@@ -4,4 +4,4 @@ import { PushNotificationToken } from "../schemas/PushNotificationToken";
|
|
|
4
4
|
import { PushNotificatioNTokenRes } from "../schemas/PushNotificationTokenRes";
|
|
5
5
|
declare const postUserRemoveTokenHandler: Handler<FlinkContext<genericAuthContext>, PushNotificationToken, PushNotificatioNTokenRes>;
|
|
6
6
|
export default postUserRemoveTokenHandler;
|
|
7
|
-
export declare const __assumedHttpMethod = "", __file = "UserPushRemoveToken.ts", __query: never[], __params: never[];
|
|
7
|
+
export declare const __assumedHttpMethod = "", __file = "src/handlers/UserPushRemoveToken.ts", __query: never[], __params: never[];
|
|
@@ -1,66 +1,29 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
13
|
-
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
-
function step(op) {
|
|
16
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
-
switch (op[0]) {
|
|
21
|
-
case 0: case 1: t = op; break;
|
|
22
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
-
default:
|
|
26
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
-
if (t[2]) _.ops.pop();
|
|
31
|
-
_.trys.pop(); continue;
|
|
32
|
-
}
|
|
33
|
-
op = body.call(thisArg, _);
|
|
34
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return _default;
|
|
36
9
|
}
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
return [4 /*yield*/, repo.getById(req.user._id)];
|
|
50
|
-
case 1:
|
|
51
|
-
user = _c.sent();
|
|
52
|
-
if (user == null) {
|
|
53
|
-
return [2 /*return*/, (0, flink_1.notFound)("User not found")];
|
|
54
|
-
}
|
|
55
|
-
user.pushNotificationTokens = user.pushNotificationTokens.filter(function (t) { return t.deviceId != req.body.deviceId; });
|
|
56
|
-
return [4 /*yield*/, repo.updateOne(user._id, {
|
|
57
|
-
pushNotificationTokens: user.pushNotificationTokens,
|
|
58
|
-
})];
|
|
59
|
-
case 2:
|
|
60
|
-
_c.sent();
|
|
61
|
-
return [2 /*return*/, { data: { status: "success" } }];
|
|
62
|
-
}
|
|
10
|
+
});
|
|
11
|
+
const _flink = require("@flink-app/flink");
|
|
12
|
+
const postUserRemoveTokenHandler = async ({ ctx, req, origin })=>{
|
|
13
|
+
let pluginName = origin || "genericAuthPlugin";
|
|
14
|
+
let repo = ctx.repos[ctx.plugins[pluginName].repoName];
|
|
15
|
+
const user = await repo.getById(req.user._id);
|
|
16
|
+
if (user == null) {
|
|
17
|
+
return (0, _flink.notFound)("User not found");
|
|
18
|
+
}
|
|
19
|
+
user.pushNotificationTokens = user.pushNotificationTokens.filter((t)=>t.deviceId != req.body.deviceId);
|
|
20
|
+
await repo.updateOne(user._id, {
|
|
21
|
+
pushNotificationTokens: user.pushNotificationTokens
|
|
63
22
|
});
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
23
|
+
return {
|
|
24
|
+
data: {
|
|
25
|
+
status: "success"
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
const _default = postUserRemoveTokenHandler;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/joel/projects/flink/flink-framework/packages/generic-auth-plugin/src/handlers/UserPushRemoveToken.ts"],"sourcesContent":["import { FlinkContext, Handler, notFound } from \"@flink-app/flink\";\nimport { genericAuthContext } from \"../genericAuthContext\";\nimport { PushNotificationToken } from \"../schemas/PushNotificationToken\";\nimport { PushNotificatioNTokenRes } from \"../schemas/PushNotificationTokenRes\";\nimport { User } from \"../schemas/User\";\n\nconst postUserRemoveTokenHandler: Handler<FlinkContext<genericAuthContext>, PushNotificationToken, PushNotificatioNTokenRes> = async ({ ctx, req, origin }) => {\n let pluginName = origin || \"genericAuthPlugin\";\n let repo = ctx.repos[(<any>ctx.plugins)[pluginName].repoName];\n\n const user = <User>await repo.getById(req.user._id);\n\n if (user == null) {\n return notFound(\"User not found\");\n }\n\n user.pushNotificationTokens = user.pushNotificationTokens.filter((t) => t.deviceId != req.body.deviceId);\n\n await repo.updateOne(user._id, {\n pushNotificationTokens: user.pushNotificationTokens,\n });\n\n return { data: { status: \"success\" } };\n};\n\nexport default postUserRemoveTokenHandler;\n"],"names":["postUserRemoveTokenHandler","ctx","req","origin","pluginName","repo","repos","plugins","repoName","user","getById","_id","notFound","pushNotificationTokens","filter","t","deviceId","body","updateOne","data","status"],"mappings":";;;;+BAyBA;;;eAAA;;;uBAzBgD;AAMhD,MAAMA,6BAAyH,OAAO,EAAEC,GAAG,EAAEC,GAAG,EAAEC,MAAM,EAAE;IACtJ,IAAIC,aAAaD,UAAU;IAC3B,IAAIE,OAAOJ,IAAIK,KAAK,CAAC,AAAML,IAAIM,OAAO,AAAC,CAACH,WAAW,CAACI,QAAQ,CAAC;IAE7D,MAAMC,OAAa,MAAMJ,KAAKK,OAAO,CAACR,IAAIO,IAAI,CAACE,GAAG;IAElD,IAAIF,QAAQ,MAAM;QACd,OAAOG,IAAAA,eAAQ,EAAC;IACpB;IAEAH,KAAKI,sBAAsB,GAAGJ,KAAKI,sBAAsB,CAACC,MAAM,CAAC,CAACC,IAAMA,EAAEC,QAAQ,IAAId,IAAIe,IAAI,CAACD,QAAQ;IAEvG,MAAMX,KAAKa,SAAS,CAACT,KAAKE,GAAG,EAAE;QAC3BE,wBAAwBJ,KAAKI,sBAAsB;IACvD;IAEA,OAAO;QAAEM,MAAM;YAAEC,QAAQ;QAAU;IAAE;AACzC;MAEA,WAAepB"}
|
|
@@ -3,4 +3,4 @@ import { genericAuthContext } from "../genericAuthContext";
|
|
|
3
3
|
import { UserTokenRes } from "../schemas/UserTokenRes";
|
|
4
4
|
declare const getUserTokenHandler: Handler<FlinkContext<genericAuthContext>, UserTokenRes>;
|
|
5
5
|
export default getUserTokenHandler;
|
|
6
|
-
export declare const __assumedHttpMethod = "", __file = "UserToken.ts", __query: never[], __params: never[];
|
|
6
|
+
export declare const __assumedHttpMethod = "", __file = "src/handlers/UserToken.ts", __query: never[], __params: never[];
|
|
@@ -1,66 +1,32 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
13
|
-
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
-
function step(op) {
|
|
16
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
-
switch (op[0]) {
|
|
21
|
-
case 0: case 1: t = op; break;
|
|
22
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
-
default:
|
|
26
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
-
if (t[2]) _.ops.pop();
|
|
31
|
-
_.trys.pop(); continue;
|
|
32
|
-
}
|
|
33
|
-
op = body.call(thisArg, _);
|
|
34
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return _default;
|
|
36
9
|
}
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
return [2 /*return*/, (0, flink_1.internalServerError)()];
|
|
57
|
-
}
|
|
58
|
-
return [4 /*yield*/, ctx.auth.createToken({ username: user.username.toLowerCase(), _id: user._id }, user.roles)];
|
|
59
|
-
case 2:
|
|
60
|
-
token = _c.sent();
|
|
61
|
-
return [2 /*return*/, { data: { token: token } }];
|
|
10
|
+
});
|
|
11
|
+
const _flink = require("@flink-app/flink");
|
|
12
|
+
const getUserTokenHandler = async ({ ctx, req, origin })=>{
|
|
13
|
+
let pluginName = origin || "genericAuthPlugin";
|
|
14
|
+
let repo = ctx.repos[ctx.plugins[pluginName].repoName];
|
|
15
|
+
const user = await repo.getById(req.user._id);
|
|
16
|
+
if (user == null) {
|
|
17
|
+
return (0, _flink.notFound)("User not found");
|
|
18
|
+
}
|
|
19
|
+
if (ctx.auth == null) {
|
|
20
|
+
return (0, _flink.internalServerError)();
|
|
21
|
+
}
|
|
22
|
+
const token = await ctx.auth.createToken({
|
|
23
|
+
username: user.username.toLowerCase(),
|
|
24
|
+
_id: user._id
|
|
25
|
+
}, user.roles);
|
|
26
|
+
return {
|
|
27
|
+
data: {
|
|
28
|
+
token: token
|
|
62
29
|
}
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
exports.__assumedHttpMethod = "", exports.__file = "UserToken.ts", exports.__query = [], exports.__params = [];
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
const _default = getUserTokenHandler;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/joel/projects/flink/flink-framework/packages/generic-auth-plugin/src/handlers/UserToken.ts"],"sourcesContent":["import { FlinkContext, Handler, internalServerError, notFound } from \"@flink-app/flink\";\nimport { genericAuthContext } from \"../genericAuthContext\";\nimport { UserTokenRes } from \"../schemas/UserTokenRes\";\n\nconst getUserTokenHandler: Handler<FlinkContext<genericAuthContext>, UserTokenRes> = async ({ ctx, req, origin }) => {\n let pluginName = origin || \"genericAuthPlugin\";\n let repo = ctx.repos[(<any>ctx.plugins)[pluginName].repoName];\n\n const user = await repo.getById(req.user._id);\n if (user == null) {\n return notFound(\"User not found\");\n }\n if (ctx.auth == null) {\n return internalServerError();\n }\n\n const token = await ctx.auth.createToken({ username: user.username.toLowerCase(), _id: user._id }, user.roles);\n\n return { data: { token: token } };\n};\n\nexport default getUserTokenHandler;\n"],"names":["getUserTokenHandler","ctx","req","origin","pluginName","repo","repos","plugins","repoName","user","getById","_id","notFound","auth","internalServerError","token","createToken","username","toLowerCase","roles","data"],"mappings":";;;;+BAqBA;;;eAAA;;;uBArBqE;AAIrE,MAAMA,sBAA+E,OAAO,EAAEC,GAAG,EAAEC,GAAG,EAAEC,MAAM,EAAE;IAC5G,IAAIC,aAAaD,UAAU;IAC3B,IAAIE,OAAOJ,IAAIK,KAAK,CAAC,AAAML,IAAIM,OAAO,AAAC,CAACH,WAAW,CAACI,QAAQ,CAAC;IAE7D,MAAMC,OAAO,MAAMJ,KAAKK,OAAO,CAACR,IAAIO,IAAI,CAACE,GAAG;IAC5C,IAAIF,QAAQ,MAAM;QACd,OAAOG,IAAAA,eAAQ,EAAC;IACpB;IACA,IAAIX,IAAIY,IAAI,IAAI,MAAM;QAClB,OAAOC,IAAAA,0BAAmB;IAC9B;IAEA,MAAMC,QAAQ,MAAMd,IAAIY,IAAI,CAACG,WAAW,CAAC;QAAEC,UAAUR,KAAKQ,QAAQ,CAACC,WAAW;QAAIP,KAAKF,KAAKE,GAAG;IAAC,GAAGF,KAAKU,KAAK;IAE7G,OAAO;QAAEC,MAAM;YAAEL,OAAOA;QAAM;IAAE;AACpC;MAEA,WAAef"}
|