{- Section 12 in Foundation grant, etc -} {-# LANGUAGE OverloadedStrings #-} module Language.SQL.SimpleSQL.SQL2011AccessControl (sql2011AccessControlTests) where import Language.SQL.SimpleSQL.TestTypes import Language.SQL.SimpleSQL.Syntax import Language.SQL.SimpleSQL.TestRunners import Data.Text (Text) sql2011AccessControlTests :: TestItem sql2011AccessControlTests = Group "sql 2011 access control tests" [ {- 12 Access control 12.1 ::= | 12.2 ::= GRANT TO [ { }... ] [ WITH HIERARCHY OPTION ] [ WITH GRANT OPTION ] [ GRANTED BY ] 12.3 ::= ON ::= [ TABLE ] | DOMAIN | COLLATION | CHARACTER SET | TRANSLATION | TYPE | SEQUENCE | ::= ALL PRIVILEGES | [ { }... ] ::= SELECT | SELECT | SELECT | DELETE | INSERT [ ] | UPDATE [ ] | REFERENCES [ ] | USAGE | TRIGGER | UNDER | EXECUTE ::= [ { }... ] ::= ::= PUBLIC | ::= CURRENT_USER | CURRENT_ROLE -} s "grant all privileges on tbl1 to role1" $ GrantPrivilege [PrivAll] (PrivTable [Name Nothing "tbl1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant all privileges on tbl1 to role1,role2" $ GrantPrivilege [PrivAll] (PrivTable [Name Nothing "tbl1"]) [Name Nothing "role1",Name Nothing "role2"] WithoutGrantOption ,s "grant all privileges on tbl1 to role1 with grant option" $ GrantPrivilege [PrivAll] (PrivTable [Name Nothing "tbl1"]) [Name Nothing "role1"] WithGrantOption ,s "grant all privileges on table tbl1 to role1" $ GrantPrivilege [PrivAll] (PrivTable [Name Nothing "tbl1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant all privileges on domain mydom to role1" $ GrantPrivilege [PrivAll] (PrivDomain [Name Nothing "mydom"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant all privileges on type t1 to role1" $ GrantPrivilege [PrivAll] (PrivType [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant all privileges on sequence s1 to role1" $ GrantPrivilege [PrivAll] (PrivSequence [Name Nothing "s1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant select on table t1 to role1" $ GrantPrivilege [PrivSelect []] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant select(a,b) on table t1 to role1" $ GrantPrivilege [PrivSelect [Name Nothing "a", Name Nothing "b"]] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant delete on table t1 to role1" $ GrantPrivilege [PrivDelete] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant insert on table t1 to role1" $ GrantPrivilege [PrivInsert []] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant insert(a,b) on table t1 to role1" $ GrantPrivilege [PrivInsert [Name Nothing "a", Name Nothing "b"]] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant update on table t1 to role1" $ GrantPrivilege [PrivUpdate []] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant update(a,b) on table t1 to role1" $ GrantPrivilege [PrivUpdate [Name Nothing "a", Name Nothing "b"]] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant references on table t1 to role1" $ GrantPrivilege [PrivReferences []] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant references(a,b) on table t1 to role1" $ GrantPrivilege [PrivReferences [Name Nothing "a", Name Nothing "b"]] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant usage on table t1 to role1" $ GrantPrivilege [PrivUsage] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant trigger on table t1 to role1" $ GrantPrivilege [PrivTrigger] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant execute on specific function f to role1" $ GrantPrivilege [PrivExecute] (PrivFunction [Name Nothing "f"]) [Name Nothing "role1"] WithoutGrantOption ,s "grant select,delete on table t1 to role1" $ GrantPrivilege [PrivSelect [], PrivDelete] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] WithoutGrantOption {- skipping for now: what is 'under' action? collation, character set, translation, member thing, methods for review some pretty big things missing in the standard: schema, database functions, etc., by argument types since they can be overloaded 12.4 ::= CREATE ROLE [ WITH ADMIN ] -} ,s "create role rolee" $ CreateRole (Name Nothing "rolee") {- 12.5 ::= GRANT [ { }... ] TO [ { }... ] [ WITH ADMIN OPTION ] [ GRANTED BY ] ::= -} ,s "grant role1 to public" $ GrantRole [Name Nothing "role1"] [Name Nothing "public"] WithoutAdminOption ,s "grant role1,role2 to role3,role4" $ GrantRole [Name Nothing "role1",Name Nothing "role2"] [Name Nothing "role3", Name Nothing "role4"] WithoutAdminOption ,s "grant role1 to role3 with admin option" $ GrantRole [Name Nothing "role1"] [Name Nothing "role3"] WithAdminOption {- 12.6 ::= DROP ROLE -} ,s "drop role rolee" $ DropRole (Name Nothing "rolee") {- 12.7 ::= | ::= REVOKE [ ] FROM [ { }... ] [ GRANTED BY ] ::= GRANT OPTION FOR | HIERARCHY OPTION FOR -} ,s "revoke select on t1 from role1" $ RevokePrivilege NoGrantOptionFor [PrivSelect []] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1"] DefaultDropBehaviour ,s "revoke grant option for select on t1 from role1,role2 cascade" $ RevokePrivilege GrantOptionFor [PrivSelect []] (PrivTable [Name Nothing "t1"]) [Name Nothing "role1",Name Nothing "role2"] Cascade {- ::= REVOKE [ ADMIN OPTION FOR ] [ { }... ] FROM [ { }... ] [ GRANTED BY ] ::= -} ,s "revoke role1 from role2" $ RevokeRole NoAdminOptionFor [Name Nothing "role1"] [Name Nothing "role2"] DefaultDropBehaviour ,s "revoke role1,role2 from role3,role4" $ RevokeRole NoAdminOptionFor [Name Nothing "role1",Name Nothing "role2"] [Name Nothing "role3",Name Nothing "role4"] DefaultDropBehaviour ,s "revoke admin option for role1 from role2 cascade" $ RevokeRole AdminOptionFor [Name Nothing "role1"] [Name Nothing "role2"] Cascade ] s :: HasCallStack => Text -> Statement -> TestItem s src ast = testStatement ansi2011 src ast