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
113
114
115
|
-module(spe_player).
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% TYPES %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% EXPORTS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-export([generate/3]).
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% LOCAL FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-spec reserve_login (binary(), binary()) -> 'ok'.
reserve_login (UsernameLC, EmailLC) ->
shr_janitor:new(login_db, UsernameLC),
shr_janitor:new(login_db, EmailLC),
ok = shr_database:reserve(login_db, UsernameLC, janitor),
ok = shr_database:reserve(login_db, EmailLC, janitor),
ok.
-spec finalize_login (binary(), binary(), binary()) -> 'ok'.
finalize_login (UsernameLC, EmailLC, PlayerID) ->
LoginUpdateQueryOps =
[
shr_db_query:set_value(PlayerID),
shr_db_query:set_read_permission(any),
shr_db_query:set_write_permission([{user, PlayerID}])
],
ok =
shr_database:commit
(
shr_db_query:new(login_db, UsernameLC, janitor, LoginUpdateQueryOps)
),
ok =
shr_database:commit
(
shr_db_query:new(login_db, EmailLC, janitor, LoginUpdateQueryOps)
),
'ok'.
-spec generate_inventory (binary()) -> binary().
generate_inventory (PlayerID) ->
Inventory = shr_inventory:new(PlayerID),
{ok, InventoryID} =
shr_database:insert
(
inventory_db,
any,
[{user, PlayerID}],
Inventory
),
InventoryID.
-spec generate_roster (binary()) -> binary().
generate_roster (PlayerID) ->
Roster = rst_roster:new(PlayerID),
{ok, RosterID} =
shr_database:insert
(
roster_db,
any,
[{user, PlayerID}],
Roster
),
RosterID.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% EXPORTED FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-spec generate (binary(), binary(), binary()) -> shr_player:type().
generate (Username, Password, Email) ->
UsernameLC = string:lowercase(Username),
EmailLC = string:lowercase(Email),
ok = reserve_login(UsernameLC, EmailLC),
Player = shr_player:new(<<"">>, Username, Password, Email),
{ok, PlayerID} = shr_database:insert(player_db, janitor, janitor, Player),
shr_janitor:new(player_db, PlayerID),
InvID = generate_inventory(PlayerID),
RosterID = generate_roster(PlayerID),
PlayerUpdateQueryOps =
[
shr_db_query:set_field(shr_player:get_id_field(), PlayerID),
shr_db_query:set_field(shr_player:get_inventory_id_field(), InvID),
shr_db_query:set_field(shr_player:get_roster_id_field(), RosterID),
shr_db_query:set_read_permission(any),
shr_db_query:set_write_permission([{user, PlayerID}])
],
ok = finalize_login(UsernameLC, EmailLC, PlayerID),
ok =
shr_database:commit
(
shr_db_query:new(player_db, PlayerID, janitor, PlayerUpdateQueryOps)
),
Result = shr_player:set_id(PlayerID, Player),
Result.
|