Check for empty file paths
[hcoop/portal.git] / init.sig
CommitLineData
208e2cbc
AC
1signature INIT = sig
2 structure C : SQL_CLIENT
3
e84acecc 4 val scratchDir : string
edeb626e 5 val urlPrefix : string
6f91863c 6 val boardEmail : string
edeb626e 7
208e2cbc 8 exception Access of string
f3f3ad24 9 exception NeedTos
208e2cbc 10
93f77ca7
AC
11 val emailSuffix : string
12
f3f3ad24 13 type user = {id : int, name : string, rname : string, bal : int, joined : C.timestamp,
aaa50197 14 app : int, shares : int}
208e2cbc 15
ee587f7f
AC
16 val rowError : string * C.value list -> 'a
17
18 val mkUserRow : C.value list -> user
208e2cbc 19
dda99898
AC
20 (* Direct access to database connections *)
21 val conn : unit -> C.conn
22
208e2cbc
AC
23 (* Open or close a session, wrapped in a transaction *)
24 val init : unit -> unit
25 val done : unit -> unit
26
ee587f7f 27 val nextSeq : C.conn * string -> int
208e2cbc
AC
28
29 (* Fun with users *)
30
31 val lookupUser : int -> user
32 val listUsers : unit -> user list
aaa50197
AC
33 val addUser : string * string * int * int * int -> int
34 (* Pass name, real name, balance ID, and share count *)
208e2cbc
AC
35 val modUser : user -> unit
36 val deleteUser : int -> string
aaa50197 37 val byPledge : unit -> user list
60754922 38 val unmigratedUsers : unit -> user list
208e2cbc
AC
39
40 val validUsername : string -> bool
41 val userNameToId : string -> int option
42
43 val getDb : unit -> C.conn
44
45 val getUser : unit -> user
46 val getUserId : unit -> int
47 val getUserName : unit -> string
98a5f121
AC
48
49 val dateString : unit -> string
f3f3ad24
AC
50
51 val grandfatherUsers : unit -> unit
18eeb749
AC
52
53 type node = {id : int, name : string, descr : string, debian : string}
54
55 val listNodes : unit -> node list
56 val nodeName : int -> string
57 val nodeDebian : int -> string
30b8ceb4
AC
58
59 val explain : exn -> string
60 val tokens : unit -> string
61 val tokensForked : unit -> unit
93f77ca7 62end