1 | #!/bin/sh |
---|
2 | |
---|
3 | # geni s2_run_query |
---|
4 | # using aba_prover_yap |
---|
5 | |
---|
6 | echo "=====================s2_run_query==================" |
---|
7 | |
---|
8 | pwd=`pwd` |
---|
9 | |
---|
10 | eloc=`which abac_prover_yap | sed 's/\/abac_prover_yap//'` |
---|
11 | if [ "$eloc" = "" ]; then |
---|
12 | echo "ERROR: abac_prover_yap is not in the search path!!!" |
---|
13 | exit 1 |
---|
14 | fi |
---|
15 | |
---|
16 | keyloc=$pwd |
---|
17 | |
---|
18 | g=`creddy --keyid --cert $keyloc/G_ID.pem` |
---|
19 | pa=`creddy --keyid --cert $keyloc/PA_ID.pem` |
---|
20 | sa=`creddy --keyid --cert $keyloc/SA_ID.pem` |
---|
21 | |
---|
22 | drd=`creddy --keyid --cert $keyloc/Drd_ID.pem` |
---|
23 | frank=`creddy --keyid --cert $keyloc/Frank_ID.pem` |
---|
24 | dan=`creddy --keyid --cert $keyloc/Dan_ID.pem` |
---|
25 | jim=`creddy --keyid --cert $keyloc/Jim_ID.pem` |
---|
26 | nancy=`creddy --keyid --cert $keyloc/Nancy_ID.pem` |
---|
27 | lisa=`creddy --keyid --cert $keyloc/Lisa_ID.pem` |
---|
28 | cary=`creddy --keyid --cert $keyloc/Cary_ID.pem` |
---|
29 | alice=`creddy --keyid --cert $keyloc/Alice_ID.pem` |
---|
30 | |
---|
31 | ## dump all credentials |
---|
32 | env ABAC_CN=1 $eloc/abac_prover_yap --keystore $keyloc --dump s2_creds_dump |
---|
33 | |
---|
34 | # runMember Cary $cary good bad |
---|
35 | runMember() { |
---|
36 | id=$2 |
---|
37 | proj="'$3'" |
---|
38 | role="[keyid:$pa].role:member_([string:$proj])" |
---|
39 | prin="[keyid:$id]" |
---|
40 | echo " " |
---|
41 | echo "===$4============ PA.member_($3)<-?-$1" |
---|
42 | $eloc/abac_prover_yap --keystore $keyloc --role "$role" --principal "$prin" |
---|
43 | |
---|
44 | role="[keyid:$pa].role:member([string:$proj])" |
---|
45 | prin="[keyid:$id]" |
---|
46 | echo " " |
---|
47 | echo "===$5============ PA.member("$3")<-?-$1" |
---|
48 | $eloc/abac_prover_yap --keystore $keyloc --role "$role" --principal "$prin" |
---|
49 | } |
---|
50 | |
---|
51 | |
---|
52 | ## PA.member_("proj1") <- Cary |
---|
53 | #[keyid:PA].role:member_([string:'proj1']) <-?- [keyid:Cary] |
---|
54 | ## PA.member("proj1") <- Cary |
---|
55 | #[keyid:PA].role:member([string:'proj1']) <-?- [keyid:Cary] |
---|
56 | |
---|
57 | runMember Frank $frank proj1 bad good |
---|
58 | runMember Dan $dan proj1 good good |
---|
59 | runMember Dan $dan proj2 good good |
---|
60 | runMember Jim $jim proj1 bad good |
---|
61 | runMember Nancy $nancy proj1 good good |
---|
62 | runMember Lisa $lisa proj1 bad good |
---|
63 | runMember Cary $cary proj1 bad good |
---|
64 | runMember Alice $alice proj1 good good |
---|
65 | runMember Drd $drd proj1 good good |
---|
66 | |
---|
67 | echo "\n\n" |
---|