-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathabaco-permissions.sh
More file actions
executable file
·94 lines (80 loc) · 2.36 KB
/
abaco-permissions.sh
File metadata and controls
executable file
·94 lines (80 loc) · 2.36 KB
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
#!/bin/bash
THIS=$(basename $0)
THIS=${THIS%.sh}
THIS=${THIS//[-]/ }
HELP="
Usage: ${THIS} [OPTION]... [ACTORID]
Updates and lists user permissions for a given actor. If a user
and access level is provided, permissions are updated; otherwise,
the current permissions are listed. Valid access levels are NONE,
READ, EXECUTE, and UPDATE.
Options:
-h show help message
-z api access token
-u update this user's permission
-p permission level
-v verbose output
-V very verbose output
"
# function usage() { echo "$0 usage:" && grep " .)\ #" $0; exit 0; }
function usage() { echo "$HELP"; exit 0; }
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
source "$DIR/abaco-common.sh"
tok=
while getopts ":hvu:p:z:V" o; do
case "${o}" in
z) # custom token
tok=${OPTARG}
;;
u) # user to update permissions
user=${OPTARG}
;;
p) # permission level
permission=${OPTARG}
;;
v) # verbose
verbose="true"
;;
V) # verbose
very_verbose="true"
;;
h | *) # print help text
usage
;;
esac
done
shift $((OPTIND-1))
if [ ! -z "$tok" ]; then TOKEN=$tok; fi
if [[ "$very_verbose" == "true" ]];
then
verbose="true"
fi
actor="$1"
if [ -z "$actor" ]; then
echo "Please specify actor ID"
usage
fi
# POST if both user and permission provided
# GET if neither provided
# throw error if only one provided
if [ ! -z "$user" ] && [ ! -z "$permission" ]; then
data="{\"user\": \"${user}\", \"level\": \"${permission}\"}"
curlCommand="curl -X POST -sk -H \"Authorization: Bearer $TOKEN\" -H \"Content-Type: application/json\" --data '$data' 'https://api.sd2e.org/actors/v2/${actor}/permissions'"
elif [ -z "$user" ] && [ -z "$permission" ]; then
curlCommand="curl -sk -H \"Authorization: Bearer $TOKEN\" 'https://api.sd2e.org/actors/v2/${actor}/permissions'"
else
echo "Please specify both a user (-u) and a permission level (-p) to update permissions for actor $actor"
usage
fi
function filter() {
eval $@ | jq -r '.result | to_entries[] | [.key, .value] | "\(.[0]) \(.[1])"' | column -t
}
if [[ "$very_verbose" == "true" ]];
then
echo "Calling $curlCommand"
fi
if [[ "$verbose" == "true" ]]; then
eval $curlCommand
else
filter $curlCommand
fi