privilege_topic.sim 3.9 KB
Newer Older
S
Shengliang Guan 已提交
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 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156
system sh/stop_dnodes.sh
system sh/deploy.sh -n dnode1 -i 1
system sh/exec.sh -n dnode1 -s start
sql connect

print =============== create db
sql create database root_d1 vgroups 1;
sql create database root_d2 vgroups 1;
sql create database root_d3 vgroups 1;

sql show user privileges
if $rows != 1 then 
  return -1
endi
if $data(root)[1] != all then 
  return -1
endi
if $data(root)[2] != all then 
  return -1
endi

print =============== create users
sql create user user1 PASS 'taosdata'
sql create user user2 PASS 'taosdata'
sql create user user3 PASS 'taosdata'
sql create user user4 PASS 'taosdata'
sql create user user5 PASS 'taosdata'
sql create user user6 PASS 'taosdata'
sql alter user user1 sysinfo 0

sql select * from information_schema.ins_users
if $rows != 7 then 
  return -1
endi

sql GRANT read ON root_d1.* to user1;
sql GRANT write ON root_d2.* to user2;
sql GRANT read ON root_d3.* to user3;
sql GRANT write ON root_d3.* to user3;

sql show user privileges
if $rows != 5 then 
  return -1
endi
if $data(user1)[1] != read then 
  return -1
endi
if $data(user1)[2] != root_d1 then 
  return -1
endi
if $data(user2)[1] != write then 
  return -1
endi
if $data(user2)[2] != root_d2 then 
  return -1
endi

print =============== create topis
sql use root_d1
sql create table root_d1_stb (ts timestamp, i int) tags (j int)
sql create topic root_d1_topic1 as select ts, i from root_d1_stb
sql create topic root_d1_topic2 as select ts, i from root_d1_stb
sql create topic root_d1_topic3 as select ts, i from root_d1_stb
sql create topic root_d1_topic4 as select ts, i from root_d1_stb

sql show user privileges
if $rows != 5 then 
  return -1
endi

sql GRANT subscribe ON root_d1_topic1 TO user4
sql GRANT subscribe ON root_d1_topic2 TO user5
sql GRANT subscribe ON root_d1_topic3 TO user6
sql show user privileges
if $rows != 8 then 
  return -1
endi

if $data(user4)[1] != subscribe then 
  return -1
endi
if $data(user4)[2] != root_d1_topic1 then 
  return -1
endi
if $data(user5)[1] != subscribe then 
  return -1
endi
if $data(user5)[2] != root_d1_topic2 then 
  return -1
endi
if $data(user6)[1] != subscribe then 
  return -1
endi
if $data(user6)[2] != root_d1_topic3 then 
  return -1
endi

sql REVOKE subscribe ON root_d1_topic3 from user6
sql show user privileges
if $rows != 7 then 
  return -1
endi
if $data(user4)[1] != subscribe then 
  return -1
endi
if $data(user4)[2] != root_d1_topic1 then 
  return -1
endi
if $data(user5)[1] != subscribe then 
  return -1
endi
if $data(user5)[2] != root_d1_topic2 then 
  return -1
endi

print =============== repeat revoke/grant or invalid revoke/grant
sql GRANT subscribe ON root_d1_topic1 to user4
sql GRANT subscribe ON root_d1_topic2 to user4
sql GRANT subscribe ON root_d1_topic3 to user4
sql GRANT subscribe ON root_d1_topic1 to user5
sql GRANT subscribe ON root_d1_topic2 to user5
sql GRANT subscribe ON root_d1_topic3 to user5
sql GRANT subscribe ON root_d1_topic1 to user6
sql GRANT subscribe ON root_d1_topic2 to user6
sql GRANT subscribe ON root_d1_topic3 to user6
sql REVOKE subscribe ON root_d1_topic1 from user4
sql REVOKE subscribe ON root_d1_topic2 from user4
sql REVOKE subscribe ON root_d1_topic3 from user4
sql REVOKE subscribe ON root_d1_topic1 from user5
sql REVOKE subscribe ON root_d1_topic2 from user5
sql REVOKE subscribe ON root_d1_topic3 from user5
sql REVOKE subscribe ON root_d1_topic1 from user6
sql REVOKE subscribe ON root_d1_topic2 from user6
sql REVOKE subscribe ON root_d1_topic3 from user6

print =============== invalid revoke/grant
sql_error GRANT subscribe ON root_d1_topicx from user5
sql_error REVOKE subscribe ON root_d1_topicx from user5

print =============== check 
sql GRANT subscribe ON root_d1_topic1 TO user4
sql GRANT subscribe ON root_d1_topic2 TO user5
sql GRANT subscribe ON root_d1_topic3 TO user6
sql show user privileges
if $rows != 8 then 
  return -1
endi

print =============== re connect
print user u1 login
sql close
sql connect user1

sql_error show user privileges

system sh/exec.sh -n dnode1 -s stop -x SIGINT