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
|
-module(spe_player).
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% TYPES %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% EXPORTS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-export([generate/3]).
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% LOCAL FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% EXPORTED FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-spec generate (binary(), binary(), binary()) -> shr_player:type().
generate (Username, Password, Email) ->
UsernameLC = string:lowercase(Username),
EmailLC = string:lowercase(Email),
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),
Player = shr_player:new(<<"">>, Username, Password, Email),
{ok, PlayerID} = shr_database:insert(player_db, janitor, janitor, Player),
shr_janitor:new(player_db, PlayerID),
LoginUpdateQueryOps =
[
shr_db_query:set_value(PlayerID),
shr_db_query:set_read_permission(any),
shr_db_query:set_write_permission([{user, PlayerID}])
],
PlayerUpdateQueryOps =
[
shr_db_query:set_field(shr_player:get_id_field(), 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 =
shr_database:commit
(
shr_db_query:new(player_db, PlayerID, janitor, PlayerUpdateQueryOps)
),
Result = shr_player:set_id(PlayerID, Player),
Result.
|