forked from arbor-dev/arbor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.go
119 lines (110 loc) · 3.82 KB
/
server.go
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
116
117
118
119
/**
* Copyright © 2017, ACM@UIUC
*
* This file is part of the Groot Project.
*
* The Groot Project is open source software, released under the University of
* Illinois/NCSA Open Source License. You should have received a copy of
* this license in a file with the distribution.
**/
package arbor
import (
"fmt"
"os"
"strings"
"github.com/arbor-dev/arbor/logger"
"github.com/arbor-dev/arbor/security"
"github.com/arbor-dev/arbor/server"
)
const help = `Usage: executable [-r | --register-client client_name] [-c | --check-registration token] [-u | --unsecured]
-r | --register-client client_name -> registers a client, generates a token
-c | --check-registration token -> checks if a token is valid and returns name of client
-u | --unsecured -> runs arbor without the security layer
without args -> runs arbor with the security layer `
// Boot is a standard server CLI
//
// Provide a set of routes to serve and a port to serve on.
//
// Usage: executable [-r | --register-client client_name] [-c | --check-registration token] [-u | --unsecured]
//
// -r | --register-client client_name
// registers a client, generates a token
//
// -c | --check-registration token
// checks if a token is valid and returns name of client
//
// -u | --unsecured
// runs arbor without the security layer
//
// -l | --list-clients
// lists all registered client names
//
// -d | --delete-client client_name
// deletes the client token with the given name
//
// without args
// runs arbor with the security layer
//
// It will start the arbor instance, parsing the command arguments and execute the behavior.
func Boot(routes RouteCollection, addr string, port uint16) *server.ArborServer {
var srv *server.ArborServer
if len(os.Args) == 3 && (os.Args[1] == "--register-client" || os.Args[1] == "-r") {
RegisterClient(os.Args[2])
} else if len(os.Args) == 3 && (os.Args[1] == "--check-registration" || os.Args[1] == "-c") {
CheckRegistration(os.Args[2])
} else if len(os.Args) == 3 && (os.Args[1] == "--delete-client" || os.Args[1] == "-d") {
DeleteClient(os.Args[2])
} else if len(os.Args) == 2 && (os.Args[1] == "--list-clients" || os.Args[1] == "-l") {
ListClients()
} else if len(os.Args) == 2 && (os.Args[1] == "--unsecured" || os.Args[1] == "-u") {
logger.Log(logger.WARN, "Starting Arbor in unsecured mode")
srv = server.StartUnsecuredServer(routes.toServiceRoutes(), addr, port)
} else if len(os.Args) == 2 && (os.Args[1] == "--help" || os.Args[1] == "-h") {
fmt.Println(help)
} else if len(os.Args) > 1 {
logger.Log(logger.ERR, "Unknown Command")
fmt.Println(help)
} else {
srv = server.StartSecuredServer(routes.toServiceRoutes(), addr, port)
}
return srv
}
// RegisterClient will generate a access token for a client
//
// Currently uses a db of client names.
func RegisterClient(name string) {
security.Init()
token, err := security.AddClient(name)
if err != nil {
fmt.Println(err)
return
}
logger.Log(logger.SPEC, "Client "+name+" has been granted authorization token: "+token)
defer security.Shutdown()
}
// CheckRegistration allows you to check what client was assigned to a particular token
func CheckRegistration(token string) {
security.Init()
fmt.Println(security.IsAuthorizedClient(token))
defer security.Shutdown()
}
func ListClients() {
security.Init()
names, _ := security.ListClients()
if len(names) == 0 {
logger.Log(logger.SPEC, "No registered clients")
} else {
logger.Log(logger.SPEC, "Known clients: \n- "+strings.Join(names, "\n- "))
}
defer security.Shutdown()
}
func DeleteClient(name string) {
security.Init()
err := security.DeleteClient(name)
if err != nil {
logger.Log(logger.ERR, err.Error())
return
}
logger.Log(logger.SPEC, "Client "+name+" has been deleted.")
defer security.Shutdown()
}