forked from heroiclabs/nakama-project-template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
daily_rewards.ts
112 lines (97 loc) · 3.1 KB
/
daily_rewards.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
// Copyright 2020 The Nakama Authors
//
// 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.
function rpcReward(context: nkruntime.Context, logger: nkruntime.Logger, nk: nkruntime.Nakama, payload: string): string {
if (!context.userId) {
throw Error('No user ID in context');
}
if (payload){
throw Error('no input allowed');
}
var objectId: nkruntime.StorageReadRequest = {
collection: 'reward',
key: 'daily',
userId: context.userId,
}
var objects: nkruntime.StorageObject[];
try {
objects = nk.storageRead([ objectId ]);
} catch (error) {
logger.error('storageRead error: %s', error);
throw error;
}
var dailyReward: any = {
lastClaimUnix: 0,
}
objects.forEach(object => {
if (object.key == 'daily') {
dailyReward = object.value;
}
});
var resp = {
coinsReceived: 0,
}
var d = new Date();
d.setHours(0,0,0,0);
// If last claimed is before the new day grant a new reward!
if (dailyReward.lastClaimUnix < msecToSec(d.getTime())) {
resp.coinsReceived = 500;
// Update player wallet.
var changeset = {
coins: resp.coinsReceived,
}
try {
nk.walletUpdate(context.userId, changeset, {}, false);
} catch (error) {
logger.error('walletUpdate error: %q', error);
throw error;
}
var notification: nkruntime.NotificationRequest = {
code: 1001,
content: changeset,
persistent: true,
subject: "You've received your daily reward!",
userId: context.userId,
}
try {
nk.notificationsSend([notification]);
} catch (error) {
logger.error('notificationsSend error: %q', error);
throw error;
}
dailyReward.lastClaimUnix = msecToSec(Date.now());
var write: nkruntime.StorageWriteRequest = {
collection: 'reward',
key: 'daily',
permissionRead: 1,
permissionWrite: 0,
value: dailyReward,
userId: context.userId,
}
if (objects.length > 0) {
write.version = objects[0].version
}
try {
nk.storageWrite([ write ])
} catch (error) {
logger.error('storageWrite error: %q', error);
throw error;
}
}
var result = JSON.stringify(resp);
logger.debug('rpcReward resp: %q', result)
return result;
}
function msecToSec(n: number): number {
return Math.floor(n / 1000);
}