System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 119a811764ca0339ad710e4f021199bee7d6f38b:


0000: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 57 65 62  using System.Web
0010: 2e 53 65 63 75 72 69 74 79 3b 0a 75 73 69 6e 67  .Security;.using
0020: 20 53 79 73 74 65 6d 2e 43 6f 6e 66 69 67 75 72   System.Configur
0030: 61 74 69 6f 6e 2e 50 72 6f 76 69 64 65 72 3b 0a  ation.Provider;.
0040: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 43 6f 6c  using System.Col
0050: 6c 65 63 74 69 6f 6e 73 2e 53 70 65 63 69 61 6c  lections.Special
0060: 69 7a 65 64 3b 0a 75 73 69 6e 67 20 53 79 73 74  ized;.using Syst
0070: 65 6d 2e 43 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47  em.Collections.G
0080: 65 6e 65 72 69 63 3b 0a 75 73 69 6e 67 20 53 79  eneric;.using Sy
0090: 73 74 65 6d 3b 0a 75 73 69 6e 67 20 53 79 73 74  stem;.using Syst
00a0: 65 6d 2e 44 61 74 61 3b 0a 75 73 69 6e 67 20 53  em.Data;.using S
00b0: 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74  ystem.Data.SQLit
00c0: 65 3b 0a 75 73 69 6e 67 20 53 79 73 74 65 6d 2e  e;.using System.
00d0: 43 6f 6e 66 69 67 75 72 61 74 69 6f 6e 3b 0a 75  Configuration;.u
00e0: 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 69 61 67  sing System.Diag
00f0: 6e 6f 73 74 69 63 73 3b 0a 75 73 69 6e 67 20 53  nostics;.using S
0100: 79 73 74 65 6d 2e 57 65 62 3b 0a 75 73 69 6e 67  ystem.Web;.using
0110: 20 53 79 73 74 65 6d 2e 47 6c 6f 62 61 6c 69 7a   System.Globaliz
0120: 61 74 69 6f 6e 3b 0a 0a 0a 0a 6e 61 6d 65 73 70  ation;....namesp
0130: 61 63 65 20 53 51 4c 69 74 65 50 72 6f 76 69 64  ace SQLiteProvid
0140: 65 72 0a 7b 0a 0a 20 20 20 20 70 75 62 6c 69 63  er.{..    public
0150: 20 73 65 61 6c 65 64 20 70 61 72 74 69 61 6c 20   sealed partial 
0160: 63 6c 61 73 73 20 53 51 4c 69 74 65 52 6f 6c 65  class SQLiteRole
0170: 50 72 6f 76 69 64 65 72 20 3a 20 52 6f 6c 65 50  Provider : RoleP
0180: 72 6f 76 69 64 65 72 0a 20 20 20 20 7b 0a 0a 0a  rovider.    {...
0190: 20 20 20 20 20 20 20 20 70 72 69 76 61 74 65 20          private 
01a0: 73 74 72 69 6e 67 20 65 76 65 6e 74 53 6f 75 72  string eventSour
01b0: 63 65 20 3d 20 22 53 51 4c 69 74 65 52 6f 6c 65  ce = "SQLiteRole
01c0: 50 72 6f 76 69 64 65 72 22 3b 0a 0a 20 20 20 20  Provider";..    
01d0: 20 20 20 20 70 72 69 76 61 74 65 20 73 74 72 69      private stri
01e0: 6e 67 20 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72  ng connectionStr
01f0: 69 6e 67 3b 0a 20 20 20 20 20 20 20 20 70 72 69  ing;.        pri
0200: 76 61 74 65 20 62 6f 6f 6c 20 5f 57 72 69 74 65  vate bool _Write
0210: 45 78 63 65 70 74 69 6f 6e 73 54 6f 45 76 65 6e  ExceptionsToEven
0220: 74 4c 6f 67 20 3d 20 66 61 6c 73 65 3b 0a 20 20  tLog = false;.  
0230: 20 20 20 20 20 20 70 72 69 76 61 74 65 20 73 74        private st
0240: 72 69 6e 67 20 5f 41 70 70 6c 69 63 61 74 69 6f  ring _Applicatio
0250: 6e 4e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 70  nName;.        p
0260: 72 69 76 61 74 65 20 6c 6f 6e 67 20 5f 41 70 70  rivate long _App
0270: 49 44 3b 0a 0a 20 20 20 20 20 20 20 20 70 72 69  ID;..        pri
0280: 76 61 74 65 20 62 6f 6f 6c 20 5f 69 6e 69 74 69  vate bool _initi
0290: 61 6c 69 7a 65 64 20 3d 20 66 61 6c 73 65 3b 0a  alized = false;.
02a0: 20 20 20 20 20 20 20 20 70 72 69 76 61 74 65 20          private 
02b0: 6f 62 6a 65 63 74 20 5f 49 6e 69 74 4c 6f 63 6b  object _InitLock
02c0: 20 3d 20 6e 65 77 20 4f 62 6a 65 63 74 28 29 3b   = new Object();
02d0: 0a 20 20 20 20 20 20 20 20 70 72 69 76 61 74 65  .        private
02e0: 20 6f 62 6a 65 63 74 20 5f 41 70 70 4c 6f 63 6b   object _AppLock
02f0: 20 3d 20 6e 65 77 20 4f 62 6a 65 63 74 28 29 3b   = new Object();
0300: 0a 0a 20 20 20 20 20 20 20 20 70 75 62 6c 69 63  ..        public
0310: 20 62 6f 6f 6c 20 57 72 69 74 65 45 78 63 65 70   bool WriteExcep
0320: 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67 0a  tionsToEventLog.
0330: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
0340: 20 20 20 20 20 20 67 65 74 20 7b 20 72 65 74 75        get { retu
0350: 72 6e 20 5f 57 72 69 74 65 45 78 63 65 70 74 69  rn _WriteExcepti
0360: 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67 3b 20 7d  onsToEventLog; }
0370: 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20  .        }..    
0380: 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72      public overr
0390: 69 64 65 20 76 6f 69 64 20 49 6e 69 74 69 61 6c  ide void Initial
03a0: 69 7a 65 28 73 74 72 69 6e 67 20 6e 61 6d 65 2c  ize(string name,
03b0: 20 4e 61 6d 65 56 61 6c 75 65 43 6f 6c 6c 65 63   NameValueCollec
03c0: 74 69 6f 6e 20 63 6f 6e 66 69 67 29 0a 20 20 20  tion config).   
03d0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
03e0: 20 20 20 62 6f 6f 6c 20 54 65 6d 70 49 6e 69 74     bool TempInit
03f0: 20 3d 20 5f 69 6e 69 74 69 61 6c 69 7a 65 64 3b   = _initialized;
0400: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20  .            if 
0410: 28 5f 69 6e 69 74 69 61 6c 69 7a 65 64 29 0a 20  (_initialized). 
0420: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72                 r
0430: 65 74 75 72 6e 3b 0a 0a 20 20 20 20 20 20 20 20  eturn;..        
0440: 20 20 20 20 6c 6f 63 6b 20 28 5f 49 6e 69 74 4c      lock (_InitL
0450: 6f 63 6b 29 0a 20 20 20 20 20 20 20 20 20 20 20  ock).           
0460: 20 7b 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
0470: 20 20 20 20 69 66 20 28 63 6f 6e 66 69 67 20 3d      if (config =
0480: 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20 20  = null).        
0490: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
04a0: 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 4e 75  w new ArgumentNu
04b0: 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 63 6f 6e  llException("con
04c0: 66 69 67 22 29 3b 0a 0a 20 20 20 20 20 20 20 20  fig");..        
04d0: 20 20 20 20 20 20 20 20 69 66 20 28 6e 61 6d 65          if (name
04e0: 20 3d 3d 20 6e 75 6c 6c 20 7c 7c 20 6e 61 6d 65   == null || name
04f0: 2e 4c 65 6e 67 74 68 20 3d 3d 20 30 29 0a 20 20  .Length == 0).  
0500: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0510: 20 20 6e 61 6d 65 20 3d 20 22 53 51 4c 69 74 65    name = "SQLite
0520: 52 6f 6c 65 50 72 6f 76 69 64 65 72 22 3b 0a 0a  RoleProvider";..
0530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0540: 69 66 20 28 53 74 72 69 6e 67 2e 49 73 4e 75 6c  if (String.IsNul
0550: 6c 4f 72 45 6d 70 74 79 28 63 6f 6e 66 69 67 5b  lOrEmpty(config[
0560: 22 64 65 73 63 72 69 70 74 69 6f 6e 22 5d 29 29  "description"]))
0570: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0580: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
0590: 20 20 20 20 20 20 20 63 6f 6e 66 69 67 2e 52 65         config.Re
05a0: 6d 6f 76 65 28 22 64 65 73 63 72 69 70 74 69 6f  move("descriptio
05b0: 6e 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  n");.           
05c0: 20 20 20 20 20 20 20 20 20 63 6f 6e 66 69 67 2e           config.
05d0: 41 64 64 28 22 64 65 73 63 72 69 70 74 69 6f 6e  Add("description
05e0: 22 2c 20 22 53 51 4c 69 74 65 20 52 6f 6c 65 20  ", "SQLite Role 
05f0: 50 72 69 76 69 64 65 72 22 29 3b 0a 20 20 20 20  Privider");.    
0600: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20              }.. 
0610: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
0620: 2f 20 49 6e 69 74 69 61 6c 69 7a 65 20 74 68 65  / Initialize the
0630: 20 61 62 73 74 72 61 63 74 20 62 61 73 65 20 63   abstract base c
0640: 6c 61 73 73 2e 0a 20 20 20 20 20 20 20 20 20 20  lass..          
0650: 20 20 20 20 20 20 62 61 73 65 2e 49 6e 69 74 69        base.Initi
0660: 61 6c 69 7a 65 28 6e 61 6d 65 2c 20 63 6f 6e 66  alize(name, conf
0670: 69 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  ig);.           
0680: 20 20 20 20 20 5f 57 72 69 74 65 45 78 63 65 70       _WriteExcep
0690: 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67 20  tionsToEventLog 
06a0: 3d 20 50 72 6f 76 69 64 65 72 55 74 69 6c 69 74  = ProviderUtilit
06b0: 79 2e 47 65 74 45 78 63 65 70 74 69 6f 6e 44 65  y.GetExceptionDe
06c0: 73 69 74 69 6e 61 74 69 6f 6e 28 63 6f 6e 66 69  sitination(confi
06d0: 67 5b 22 77 72 69 74 65 45 78 63 65 70 74 69 6f  g["writeExceptio
06e0: 6e 73 54 6f 45 76 65 6e 74 4c 6f 67 22 5d 29 3b  nsToEventLog"]);
06f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0700: 20 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e   connectionStrin
0710: 67 20 3d 20 50 72 6f 76 69 64 65 72 55 74 69 6c  g = ProviderUtil
0720: 69 74 79 2e 47 65 74 43 6f 6e 6e 65 63 74 69 6f  ity.GetConnectio
0730: 6e 53 74 72 69 6e 67 28 63 6f 6e 66 69 67 5b 22  nString(config["
0740: 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e 67  connectionString
0750: 4e 61 6d 65 22 5d 29 3b 0a 20 20 20 20 20 20 20  Name"]);.       
0760: 20 20 20 20 20 20 20 20 20 41 70 70 6c 69 63 61           Applica
0770: 74 69 6f 6e 4e 61 6d 65 20 3d 20 50 72 6f 76 69  tionName = Provi
0780: 64 65 72 55 74 69 6c 69 74 79 2e 47 65 74 41 70  derUtility.GetAp
0790: 70 6c 69 63 61 74 69 6f 6e 4e 61 6d 65 28 63 6f  plicationName(co
07a0: 6e 66 69 67 5b 22 61 70 70 6c 69 63 61 74 69 6f  nfig["applicatio
07b0: 6e 4e 61 6d 65 22 5d 29 3b 0a 0a 20 20 20 20 20  nName"]);..     
07c0: 20 20 20 20 20 20 20 20 20 20 20 5f 69 6e 69 74             _init
07d0: 69 61 6c 69 7a 65 64 20 3d 20 74 72 75 65 3b 0a  ialized = true;.
07e0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
07f0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
0800: 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20  public override 
0810: 73 74 72 69 6e 67 20 41 70 70 6c 69 63 61 74 69  string Applicati
0820: 6f 6e 4e 61 6d 65 0a 20 20 20 20 20 20 20 20 7b  onName.        {
0830: 0a 20 20 20 20 20 20 20 20 20 20 20 20 67 65 74  .            get
0840: 20 7b 20 72 65 74 75 72 6e 20 5f 41 70 70 6c 69   { return _Appli
0850: 63 61 74 69 6f 6e 4e 61 6d 65 3b 20 7d 0a 20 20  cationName; }.  
0860: 20 20 20 20 20 20 20 20 20 20 73 65 74 0a 20 20            set.  
0870: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
0880: 20 20 20 20 20 20 20 20 20 20 20 20 6c 6f 63 6b              lock
0890: 20 28 5f 41 70 70 4c 6f 63 6b 29 0a 20 20 20 20   (_AppLock).    
08a0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20              {.  
08b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08c0: 20 20 5f 41 70 70 6c 69 63 61 74 69 6f 6e 4e 61    _ApplicationNa
08d0: 6d 65 20 3d 20 76 61 6c 75 65 3b 0a 20 20 20 20  me = value;.    
08e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08f0: 5f 41 70 70 49 44 20 3d 20 50 72 6f 76 69 64 65  _AppID = Provide
0900: 72 55 74 69 6c 69 74 79 2e 47 65 74 41 70 70 6c  rUtility.GetAppl
0910: 69 63 61 74 69 6f 6e 49 44 28 63 6f 6e 6e 65 63  icationID(connec
0920: 74 69 6f 6e 53 74 72 69 6e 67 2c 20 76 61 6c 75  tionString, valu
0930: 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  e);.            
0940: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
0950: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
0960: 20 20 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65        public ove
0970: 72 72 69 64 65 20 76 6f 69 64 20 41 64 64 55 73  rride void AddUs
0980: 65 72 73 54 6f 52 6f 6c 65 73 28 73 74 72 69 6e  ersToRoles(strin
0990: 67 5b 5d 20 75 73 65 72 6e 61 6d 65 73 2c 20 73  g[] usernames, s
09a0: 74 72 69 6e 67 5b 5d 20 72 6f 6c 65 6e 61 6d 65  tring[] rolename
09b0: 73 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  s).        {.   
09c0: 20 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 68           foreach
09d0: 20 28 73 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d   (string rolenam
09e0: 65 20 69 6e 20 72 6f 6c 65 6e 61 6d 65 73 29 0a  e in rolenames).
09f0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20              {.  
0a00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66                if
0a10: 20 28 21 52 6f 6c 65 45 78 69 73 74 73 28 72 6f   (!RoleExists(ro
0a20: 6c 65 6e 61 6d 65 29 29 0a 20 20 20 20 20 20 20  lename)).       
0a30: 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20           {.     
0a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74                 t
0a50: 68 72 6f 77 20 6e 65 77 20 50 72 6f 76 69 64 65  hrow new Provide
0a60: 72 45 78 63 65 70 74 69 6f 6e 28 22 52 6f 6c 65  rException("Role
0a70: 20 6e 61 6d 65 20 6e 6f 74 20 66 6f 75 6e 64 2e   name not found.
0a80: 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ");.            
0a90: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
0aa0: 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 20    }..           
0ab0: 20 66 6f 72 65 61 63 68 20 28 73 74 72 69 6e 67   foreach (string
0ac0: 20 75 73 65 72 6e 61 6d 65 20 69 6e 20 75 73 65   username in use
0ad0: 72 6e 61 6d 65 73 29 0a 20 20 20 20 20 20 20 20  rnames).        
0ae0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
0af0: 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 73        foreach (s
0b00: 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d 65 20 69  tring rolename i
0b10: 6e 20 72 6f 6c 65 6e 61 6d 65 73 29 0a 20 20 20  n rolenames).   
0b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20               {. 
0b30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b40: 20 20 20 69 66 20 28 49 73 55 73 65 72 49 6e 52     if (IsUserInR
0b50: 6f 6c 65 28 75 73 65 72 6e 61 6d 65 2c 20 72 6f  ole(username, ro
0b60: 6c 65 6e 61 6d 65 29 29 0a 20 20 20 20 20 20 20  lename)).       
0b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20               {. 
0b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b90: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
0ba0: 20 50 72 6f 76 69 64 65 72 45 78 63 65 70 74 69   ProviderExcepti
0bb0: 6f 6e 28 22 55 73 65 72 20 69 73 20 61 6c 72 65  on("User is alre
0bc0: 61 64 79 20 69 6e 20 72 6f 6c 65 2e 22 29 3b 0a  ady in role.");.
0bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0be0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
0bf0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
0c00: 20 20 20 20 7d 0a 0a 0a 20 20 20 20 20 20 20 20      }...        
0c10: 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63      SQLiteConnec
0c20: 74 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e 65 77 20  tion conn = new 
0c30: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
0c40: 28 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e  (connectionStrin
0c50: 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  g);.            
0c60: 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63 6d  SQLiteCommand cm
0c70: 64 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f  d = new SQLiteCo
0c80: 6d 6d 61 6e 64 28 52 6f 6c 65 53 71 6c 2e 41 64  mmand(RoleSql.Ad
0c90: 64 55 73 65 72 54 6f 52 6f 6c 65 2c 20 63 6f 6e  dUserToRole, con
0ca0: 6e 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20  n);..           
0cb0: 20 53 51 4c 69 74 65 50 61 72 61 6d 65 74 65 72   SQLiteParameter
0cc0: 20 75 73 65 72 50 61 72 6d 20 3d 20 63 6d 64 2e   userParm = cmd.
0cd0: 50 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 22  Parameters.Add("
0ce0: 24 55 73 65 72 6e 61 6d 65 22 2c 20 44 62 54 79  $Username", DbTy
0cf0: 70 65 2e 53 74 72 69 6e 67 29 3b 0a 20 20 20 20  pe.String);.    
0d00: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 50 61          SQLitePa
0d10: 72 61 6d 65 74 65 72 20 72 6f 6c 65 50 61 72 6d  rameter roleParm
0d20: 20 3d 20 63 6d 64 2e 50 61 72 61 6d 65 74 65 72   = cmd.Parameter
0d30: 73 2e 41 64 64 28 22 24 52 6f 6c 65 6e 61 6d 65  s.Add("$Rolename
0d40: 22 2c 20 44 62 54 79 70 65 2e 53 74 72 69 6e 67  ", DbType.String
0d50: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 63  );.            c
0d60: 6d 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41 64  md.Parameters.Ad
0d70: 64 28 22 24 41 70 70 49 44 22 2c 20 44 62 54 79  d("$AppID", DbTy
0d80: 70 65 2e 49 6e 74 36 34 29 2e 56 61 6c 75 65 20  pe.Int64).Value 
0d90: 3d 20 5f 41 70 70 49 44 3b 0a 0a 20 20 20 20 20  = _AppID;..     
0da0: 20 20 20 20 20 20 20 53 51 4c 69 74 65 54 72 61         SQLiteTra
0db0: 6e 73 61 63 74 69 6f 6e 20 74 72 61 6e 20 3d 20  nsaction tran = 
0dc0: 6e 75 6c 6c 3b 0a 0a 20 20 20 20 20 20 20 20 20  null;..         
0dd0: 20 20 20 74 72 79 0a 20 20 20 20 20 20 20 20 20     try.         
0de0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0df0: 20 20 20 20 20 63 6f 6e 6e 2e 4f 70 65 6e 28 29       conn.Open()
0e00: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
0e10: 20 20 74 72 61 6e 20 3d 20 63 6f 6e 6e 2e 42 65    tran = conn.Be
0e20: 67 69 6e 54 72 61 6e 73 61 63 74 69 6f 6e 28 29  ginTransaction()
0e30: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
0e40: 20 20 63 6d 64 2e 54 72 61 6e 73 61 63 74 69 6f    cmd.Transactio
0e50: 6e 20 3d 20 74 72 61 6e 3b 0a 0a 20 20 20 20 20  n = tran;..     
0e60: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61             forea
0e70: 63 68 20 28 73 74 72 69 6e 67 20 75 73 65 72 6e  ch (string usern
0e80: 61 6d 65 20 69 6e 20 75 73 65 72 6e 61 6d 65 73  ame in usernames
0e90: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ).              
0ea0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
0eb0: 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 68 20          foreach 
0ec0: 28 73 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d 65  (string rolename
0ed0: 20 69 6e 20 72 6f 6c 65 6e 61 6d 65 73 29 0a 20   in rolenames). 
0ee0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0ef0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 75 73 65               use
0f10: 72 50 61 72 6d 2e 56 61 6c 75 65 20 3d 20 75 73  rParm.Value = us
0f20: 65 72 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20  ername;.        
0f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0f40: 72 6f 6c 65 50 61 72 6d 2e 56 61 6c 75 65 20 3d  roleParm.Value =
0f50: 20 72 6f 6c 65 6e 61 6d 65 3b 0a 20 20 20 20 20   rolename;.     
0f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0f70: 20 20 20 63 6d 64 2e 45 78 65 63 75 74 65 4e 6f     cmd.ExecuteNo
0f80: 6e 51 75 65 72 79 28 29 3b 0a 20 20 20 20 20 20  nQuery();.      
0f90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a                }.
0fa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0fb0: 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  }..             
0fc0: 20 20 20 74 72 61 6e 2e 43 6f 6d 6d 69 74 28 29     tran.Commit()
0fd0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a  ;.            }.
0fe0: 20 20 20 20 20 20 20 20 20 20 20 20 63 61 74 63              catc
0ff0: 68 20 28 53 51 4c 69 74 65 45 78 63 65 70 74 69  h (SQLiteExcepti
1000: 6f 6e 20 65 29 0a 20 20 20 20 20 20 20 20 20 20  on e).          
1010: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
1020: 20 20 20 20 74 72 79 0a 20 20 20 20 20 20 20 20      try.        
1030: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
1040: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74 72                tr
1050: 61 6e 2e 52 6f 6c 6c 62 61 63 6b 28 29 3b 0a 20  an.Rollback();. 
1060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
1070: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1080: 20 63 61 74 63 68 20 7b 20 7d 0a 0a 20 20 20 20   catch { }..    
1090: 20 20 20 20 20 20 20 20 20 20 20 20 50 72 6f 76              Prov
10a0: 69 64 65 72 55 74 69 6c 69 74 79 2e 48 61 6e 64  iderUtility.Hand
10b0: 6c 65 45 78 63 65 70 74 69 6f 6e 28 65 2c 20 65  leException(e, e
10c0: 76 65 6e 74 53 6f 75 72 63 65 2c 20 22 41 64 64  ventSource, "Add
10d0: 55 73 65 72 73 54 6f 52 6f 6c 65 73 22 2c 20 57  UsersToRoles", W
10e0: 72 69 74 65 45 78 63 65 70 74 69 6f 6e 73 54 6f  riteExceptionsTo
10f0: 45 76 65 6e 74 4c 6f 67 29 3b 0a 0a 20 20 20 20  EventLog);..    
1100: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
1110: 20 20 20 20 20 20 66 69 6e 61 6c 6c 79 0a 20 20        finally.  
1120: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
1130: 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e 6e              conn
1140: 2e 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20 20 20  .Close();.      
1150: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
1160: 7d 0a 20 20 20 20 20 20 20 20 70 75 62 6c 69 63  }.        public
1170: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43   override void C
1180: 72 65 61 74 65 52 6f 6c 65 28 73 74 72 69 6e 67  reateRole(string
1190: 20 72 6f 6c 65 6e 61 6d 65 29 0a 20 20 20 20 20   rolename).     
11a0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
11b0: 20 69 66 20 28 52 6f 6c 65 45 78 69 73 74 73 28   if (RoleExists(
11c0: 72 6f 6c 65 6e 61 6d 65 29 29 0a 20 20 20 20 20  rolename)).     
11d0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
11e0: 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e           throw n
11f0: 65 77 20 50 72 6f 76 69 64 65 72 45 78 63 65 70  ew ProviderExcep
1200: 74 69 6f 6e 28 22 52 6f 6c 65 20 6e 61 6d 65 20  tion("Role name 
1210: 61 6c 72 65 61 64 79 20 65 78 69 73 74 73 2e 22  already exists."
1220: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  );.            }
1230: 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 53 51  ..            SQ
1240: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63  LiteConnection c
1250: 6f 6e 6e 20 3d 20 6e 65 77 20 53 51 4c 69 74 65  onn = new SQLite
1260: 43 6f 6e 6e 65 63 74 69 6f 6e 28 63 6f 6e 6e 65  Connection(conne
1270: 63 74 69 6f 6e 53 74 72 69 6e 67 29 3b 0a 20 20  ctionString);.  
1280: 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65            SQLite
1290: 43 6f 6d 6d 61 6e 64 20 63 6d 64 20 3d 20 6e 65  Command cmd = ne
12a0: 77 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 28  w SQLiteCommand(
12b0: 52 6f 6c 65 53 71 6c 2e 43 72 65 61 74 65 52 6f  RoleSql.CreateRo
12c0: 6c 65 2c 20 63 6f 6e 6e 29 3b 0a 0a 20 20 20 20  le, conn);..    
12d0: 20 20 20 20 20 20 20 20 63 6d 64 2e 50 61 72 61          cmd.Para
12e0: 6d 65 74 65 72 73 2e 41 64 64 28 22 24 52 6f 6c  meters.Add("$Rol
12f0: 65 6e 61 6d 65 22 2c 20 44 62 54 79 70 65 2e 53  ename", DbType.S
1300: 74 72 69 6e 67 29 2e 56 61 6c 75 65 20 3d 20 72  tring).Value = r
1310: 6f 6c 65 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20  olename;.       
1320: 20 20 20 20 20 63 6d 64 2e 50 61 72 61 6d 65 74       cmd.Paramet
1330: 65 72 73 2e 41 64 64 28 22 24 41 70 70 49 44 22  ers.Add("$AppID"
1340: 2c 20 44 62 54 79 70 65 2e 49 6e 74 36 34 29 2e  , DbType.Int64).
1350: 56 61 6c 75 65 20 3d 20 5f 41 70 70 49 44 3b 0a  Value = _AppID;.
1360: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 72 79  .            try
1370: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20  .            {. 
1380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63                 c
1390: 6f 6e 6e 2e 4f 70 65 6e 28 29 3b 0a 0a 20 20 20  onn.Open();..   
13a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6d 64               cmd
13b0: 2e 45 78 65 63 75 74 65 4e 6f 6e 51 75 65 72 79  .ExecuteNonQuery
13c0: 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ();.            
13d0: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 61  }.            ca
13e0: 74 63 68 20 28 53 51 4c 69 74 65 45 78 63 65 70  tch (SQLiteExcep
13f0: 74 69 6f 6e 20 65 29 0a 20 20 20 20 20 20 20 20  tion e).        
1400: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
1410: 20 20 20 20 20 20 50 72 6f 76 69 64 65 72 55 74        ProviderUt
1420: 69 6c 69 74 79 2e 48 61 6e 64 6c 65 45 78 63 65  ility.HandleExce
1430: 70 74 69 6f 6e 28 65 2c 20 65 76 65 6e 74 53 6f  ption(e, eventSo
1440: 75 72 63 65 2c 20 22 43 72 65 61 74 65 52 6f 6c  urce, "CreateRol
1450: 65 22 2c 20 57 72 69 74 65 45 78 63 65 70 74 69  e", WriteExcepti
1460: 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67 29 3b 0a  onsToEventLog);.
1470: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
1480: 20 20 20 20 20 20 20 20 20 20 20 66 69 6e 61 6c             final
1490: 6c 79 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  ly.            {
14a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
14b0: 20 63 6f 6e 6e 2e 43 6c 6f 73 65 28 29 3b 0a 20   conn.Close();. 
14c0: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
14d0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 70       }.        p
14e0: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62  ublic override b
14f0: 6f 6f 6c 20 44 65 6c 65 74 65 52 6f 6c 65 28 73  ool DeleteRole(s
1500: 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d 65 2c 20  tring rolename, 
1510: 62 6f 6f 6c 20 74 68 72 6f 77 4f 6e 50 6f 70 75  bool throwOnPopu
1520: 6c 61 74 65 64 52 6f 6c 65 29 0a 20 20 20 20 20  latedRole).     
1530: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
1540: 20 69 66 20 28 21 52 6f 6c 65 45 78 69 73 74 73   if (!RoleExists
1550: 28 72 6f 6c 65 6e 61 6d 65 29 29 0a 20 20 20 20  (rolename)).    
1560: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
1570: 20 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20            throw 
1580: 6e 65 77 20 50 72 6f 76 69 64 65 72 45 78 63 65  new ProviderExce
1590: 70 74 69 6f 6e 28 22 52 6f 6c 65 20 64 6f 65 73  ption("Role does
15a0: 20 6e 6f 74 20 65 78 69 73 74 2e 22 29 3b 0a 20   not exist.");. 
15b0: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20 20             }..  
15c0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74 68            if (th
15d0: 72 6f 77 4f 6e 50 6f 70 75 6c 61 74 65 64 52 6f  rowOnPopulatedRo
15e0: 6c 65 20 26 26 20 47 65 74 55 73 65 72 73 49 6e  le && GetUsersIn
15f0: 52 6f 6c 65 28 72 6f 6c 65 6e 61 6d 65 29 2e 4c  Role(rolename).L
1600: 65 6e 67 74 68 20 3e 20 30 29 0a 20 20 20 20 20  ength > 0).     
1610: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
1620: 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e           throw n
1630: 65 77 20 50 72 6f 76 69 64 65 72 45 78 63 65 70  ew ProviderExcep
1640: 74 69 6f 6e 28 22 43 61 6e 6e 6f 74 20 64 65 6c  tion("Cannot del
1650: 65 74 65 20 61 20 70 6f 70 75 6c 61 74 65 64 20  ete a populated 
1660: 72 6f 6c 65 2e 22 29 3b 0a 20 20 20 20 20 20 20  role.");.       
1670: 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20       }..        
1680: 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63      SQLiteConnec
1690: 74 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e 65 77 20  tion conn = new 
16a0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
16b0: 28 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e  (connectionStrin
16c0: 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  g);.            
16d0: 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63 6d  SQLiteCommand cm
16e0: 64 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f  d = new SQLiteCo
16f0: 6d 6d 61 6e 64 28 52 6f 6c 65 53 71 6c 2e 44 65  mmand(RoleSql.De
1700: 6c 65 74 65 52 6f 6c 65 2c 20 63 6f 6e 6e 29 3b  leteRole, conn);
1710: 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6d  ..            cm
1720: 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41 64 64  d.Parameters.Add
1730: 28 22 24 52 6f 6c 65 6e 61 6d 65 22 2c 20 44 62  ("$Rolename", Db
1740: 54 79 70 65 2e 53 74 72 69 6e 67 29 2e 56 61 6c  Type.String).Val
1750: 75 65 20 3d 20 72 6f 6c 65 6e 61 6d 65 3b 0a 20  ue = rolename;. 
1760: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 50             cmd.P
1770: 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 22 24  arameters.Add("$
1780: 41 70 70 49 44 22 2c 20 44 62 54 79 70 65 2e 49  AppID", DbType.I
1790: 6e 74 36 34 29 2e 56 61 6c 75 65 20 3d 20 5f 41  nt64).Value = _A
17a0: 70 70 49 44 3b 0a 0a 0a 20 20 20 20 20 20 20 20  ppID;...        
17b0: 20 20 20 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e      SQLiteComman
17c0: 64 20 63 6d 64 32 20 3d 20 6e 65 77 20 53 51 4c  d cmd2 = new SQL
17d0: 69 74 65 43 6f 6d 6d 61 6e 64 28 52 6f 6c 65 53  iteCommand(RoleS
17e0: 71 6c 2e 44 65 6c 65 74 65 52 6f 6c 65 46 72 6f  ql.DeleteRoleFro
17f0: 6d 4d 61 70 2c 20 63 6f 6e 6e 29 3b 0a 0a 20 20  mMap, conn);..  
1800: 20 20 20 20 20 20 20 20 20 20 63 6d 64 32 2e 50            cmd2.P
1810: 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 22 24  arameters.Add("$
1820: 52 6f 6c 65 6e 61 6d 65 22 2c 20 44 62 54 79 70  Rolename", DbTyp
1830: 65 2e 53 74 72 69 6e 67 29 2e 56 61 6c 75 65 20  e.String).Value 
1840: 3d 20 72 6f 6c 65 6e 61 6d 65 3b 0a 20 20 20 20  = rolename;.    
1850: 20 20 20 20 20 20 20 20 63 6d 64 32 2e 50 61 72          cmd2.Par
1860: 61 6d 65 74 65 72 73 2e 41 64 64 28 22 24 41 70  ameters.Add("$Ap
1870: 70 49 44 22 2c 20 44 62 54 79 70 65 2e 49 6e 74  pID", DbType.Int
1880: 36 34 29 2e 56 61 6c 75 65 20 3d 20 5f 41 70 70  64).Value = _App
1890: 49 44 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20  ID;..           
18a0: 20 53 51 4c 69 74 65 54 72 61 6e 73 61 63 74 69   SQLiteTransacti
18b0: 6f 6e 20 74 72 61 6e 20 3d 20 6e 75 6c 6c 3b 0a  on tran = null;.
18c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 72 79  .            try
18d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20  .            {. 
18e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63                 c
18f0: 6f 6e 6e 2e 4f 70 65 6e 28 29 3b 0a 20 20 20 20  onn.Open();.    
1900: 20 20 20 20 20 20 20 20 20 20 20 20 74 72 61 6e              tran
1910: 20 3d 20 63 6f 6e 6e 2e 42 65 67 69 6e 54 72 61   = conn.BeginTra
1920: 6e 73 61 63 74 69 6f 6e 28 29 3b 0a 20 20 20 20  nsaction();.    
1930: 20 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e              cmd.
1940: 54 72 61 6e 73 61 63 74 69 6f 6e 20 3d 20 74 72  Transaction = tr
1950: 61 6e 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  an;.            
1960: 20 20 20 20 63 6d 64 32 2e 54 72 61 6e 73 61 63      cmd2.Transac
1970: 74 69 6f 6e 20 3d 20 74 72 61 6e 3b 0a 0a 20 20  tion = tran;..  
1980: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6d                cm
1990: 64 32 2e 45 78 65 63 75 74 65 4e 6f 6e 51 75 65  d2.ExecuteNonQue
19a0: 72 79 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20  ry();.          
19b0: 20 20 20 20 20 20 63 6d 64 2e 45 78 65 63 75 74        cmd.Execut
19c0: 65 4e 6f 6e 51 75 65 72 79 28 29 3b 0a 0a 20 20  eNonQuery();..  
19d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74 72                tr
19e0: 61 6e 2e 43 6f 6d 6d 69 74 28 29 3b 0a 20 20 20  an.Commit();.   
19f0: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
1a00: 20 20 20 20 20 20 20 63 61 74 63 68 20 28 53 51         catch (SQ
1a10: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 20 65 29  LiteException e)
1a20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20  .            {. 
1a30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74                 t
1a40: 72 79 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ry.             
1a50: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
1a60: 20 20 20 20 20 20 20 20 20 74 72 61 6e 2e 52 6f           tran.Ro
1a70: 6c 6c 62 61 63 6b 28 29 3b 0a 20 20 20 20 20 20  llback();.      
1a80: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
1a90: 20 20 20 20 20 20 20 20 20 20 20 20 63 61 74 63              catc
1aa0: 68 20 7b 20 7d 0a 0a 20 20 20 20 20 20 20 20 20  h { }..         
1ab0: 20 20 20 20 20 20 20 50 72 6f 76 69 64 65 72 55         ProviderU
1ac0: 74 69 6c 69 74 79 2e 48 61 6e 64 6c 65 45 78 63  tility.HandleExc
1ad0: 65 70 74 69 6f 6e 28 65 2c 20 65 76 65 6e 74 53  eption(e, eventS
1ae0: 6f 75 72 63 65 2c 20 22 44 65 6c 65 74 65 52 6f  ource, "DeleteRo
1af0: 6c 65 22 2c 20 57 72 69 74 65 45 78 63 65 70 74  le", WriteExcept
1b00: 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67 29 3b  ionsToEventLog);
1b10: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
1b20: 20 20 20 20 20 20 20 20 20 20 20 66 69 6e 61 6c             final
1b30: 6c 79 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  ly.            {
1b40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1b50: 20 63 6f 6e 6e 2e 43 6c 6f 73 65 28 29 3b 0a 20   conn.Close();. 
1b60: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20 20             }..  
1b70: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
1b80: 20 74 72 75 65 3b 0a 20 20 20 20 20 20 20 20 7d   true;.        }
1b90: 0a 20 20 20 20 20 20 20 20 70 75 62 6c 69 63 20  .        public 
1ba0: 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 5b  override string[
1bb0: 5d 20 47 65 74 41 6c 6c 52 6f 6c 65 73 28 29 0a  ] GetAllRoles().
1bc0: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
1bd0: 20 20 20 20 20 20 4c 69 73 74 3c 53 74 72 69 6e        List<Strin
1be0: 67 3e 20 6e 61 6d 65 73 20 3d 20 6e 65 77 20 4c  g> names = new L
1bf0: 69 73 74 3c 73 74 72 69 6e 67 3e 28 29 3b 0a 20  ist<string>();. 
1c00: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74             SQLit
1c10: 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6f 6e 6e  eConnection conn
1c20: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6e   = new SQLiteCon
1c30: 6e 65 63 74 69 6f 6e 28 63 6f 6e 6e 65 63 74 69  nection(connecti
1c40: 6f 6e 53 74 72 69 6e 67 29 3b 0a 20 20 20 20 20  onString);.     
1c50: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6d         SQLiteCom
1c60: 6d 61 6e 64 20 63 6d 64 20 3d 20 6e 65 77 20 53  mand cmd = new S
1c70: 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 28 52 6f 6c  QLiteCommand(Rol
1c80: 65 53 71 6c 2e 47 65 74 41 6c 6c 52 6f 6c 65 73  eSql.GetAllRoles
1c90: 2c 20 63 6f 6e 6e 29 3b 0a 0a 20 20 20 20 20 20  , conn);..      
1ca0: 20 20 20 20 20 20 63 6d 64 2e 50 61 72 61 6d 65        cmd.Parame
1cb0: 74 65 72 73 2e 41 64 64 28 22 24 41 70 70 49 44  ters.Add("$AppID
1cc0: 22 2c 20 44 62 54 79 70 65 2e 49 6e 74 36 34 29  ", DbType.Int64)
1cd0: 2e 56 61 6c 75 65 20 3d 20 5f 41 70 70 49 44 3b  .Value = _AppID;
1ce0: 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 53 51  ..            SQ
1cf0: 4c 69 74 65 44 61 74 61 52 65 61 64 65 72 20 72  LiteDataReader r
1d00: 65 61 64 65 72 20 3d 20 6e 75 6c 6c 3b 0a 0a 20  eader = null;.. 
1d10: 20 20 20 20 20 20 20 20 20 20 20 74 72 79 0a 20             try. 
1d20: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
1d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e               con
1d40: 6e 2e 4f 70 65 6e 28 29 3b 0a 0a 20 20 20 20 20  n.Open();..     
1d50: 20 20 20 20 20 20 20 20 20 20 20 72 65 61 64 65             reade
1d60: 72 20 3d 20 63 6d 64 2e 45 78 65 63 75 74 65 52  r = cmd.ExecuteR
1d70: 65 61 64 65 72 28 29 3b 0a 0a 20 20 20 20 20 20  eader();..      
1d80: 20 20 20 20 20 20 20 20 20 20 77 68 69 6c 65 20            while 
1d90: 28 72 65 61 64 65 72 2e 52 65 61 64 28 29 29 0a  (reader.Read()).
1da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1db0: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
1dc0: 20 20 20 20 20 20 6e 61 6d 65 73 2e 41 64 64 28        names.Add(
1dd0: 72 65 61 64 65 72 2e 47 65 74 53 74 72 69 6e 67  reader.GetString
1de0: 28 30 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20  (0));.          
1df0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
1e00: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
1e10: 20 20 63 61 74 63 68 20 28 53 51 4c 69 74 65 45    catch (SQLiteE
1e20: 78 63 65 70 74 69 6f 6e 20 65 29 0a 20 20 20 20  xception e).    
1e30: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
1e40: 20 20 20 20 20 20 20 20 20 20 50 72 6f 76 69 64            Provid
1e50: 65 72 55 74 69 6c 69 74 79 2e 48 61 6e 64 6c 65  erUtility.Handle
1e60: 45 78 63 65 70 74 69 6f 6e 28 65 2c 20 65 76 65  Exception(e, eve
1e70: 6e 74 53 6f 75 72 63 65 2c 20 22 47 65 74 41 6c  ntSource, "GetAl
1e80: 6c 52 6f 6c 65 73 22 2c 20 57 72 69 74 65 45 78  lRoles", WriteEx
1e90: 63 65 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c  ceptionsToEventL
1ea0: 6f 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  og);.           
1eb0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 66   }.            f
1ec0: 69 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20  inally.         
1ed0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
1ee0: 20 20 20 20 20 69 66 20 28 72 65 61 64 65 72 20       if (reader 
1ef0: 21 3d 20 6e 75 6c 6c 29 20 7b 20 72 65 61 64 65  != null) { reade
1f00: 72 2e 43 6c 6f 73 65 28 29 3b 20 7d 0a 20 20 20  r.Close(); }.   
1f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e               con
1f20: 6e 2e 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20 20  n.Close();.     
1f30: 20 20 20 20 20 20 20 7d 0a 0a 0a 20 20 20 20 20         }...     
1f40: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 61         return na
1f50: 6d 65 73 2e 54 6f 41 72 72 61 79 28 29 3b 0a 20  mes.ToArray();. 
1f60: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
1f70: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
1f80: 20 73 74 72 69 6e 67 5b 5d 20 47 65 74 52 6f 6c   string[] GetRol
1f90: 65 73 46 6f 72 55 73 65 72 28 73 74 72 69 6e 67  esForUser(string
1fa0: 20 75 73 65 72 6e 61 6d 65 29 0a 20 20 20 20 20   username).     
1fb0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
1fc0: 20 4c 69 73 74 3c 73 74 72 69 6e 67 3e 20 72 6f   List<string> ro
1fd0: 6c 65 73 20 3d 20 6e 65 77 20 4c 69 73 74 3c 73  les = new List<s
1fe0: 74 72 69 6e 67 3e 28 29 3b 0a 0a 20 20 20 20 20  tring>();..     
1ff0: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e         SQLiteCon
2000: 6e 65 63 74 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e  nection conn = n
2010: 65 77 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74  ew SQLiteConnect
2020: 69 6f 6e 28 63 6f 6e 6e 65 63 74 69 6f 6e 53 74  ion(connectionSt
2030: 72 69 6e 67 29 3b 0a 20 20 20 20 20 20 20 20 20  ring);.         
2040: 20 20 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64     SQLiteCommand
2050: 20 63 6d 64 20 3d 20 6e 65 77 20 53 51 4c 69 74   cmd = new SQLit
2060: 65 43 6f 6d 6d 61 6e 64 28 52 6f 6c 65 53 71 6c  eCommand(RoleSql
2070: 2e 47 65 74 52 6f 6c 65 73 46 6f 72 55 73 65 72  .GetRolesForUser
2080: 2c 20 63 6f 6e 6e 29 3b 0a 0a 20 20 20 20 20 20  , conn);..      
2090: 20 20 20 20 20 20 63 6d 64 2e 50 61 72 61 6d 65        cmd.Parame
20a0: 74 65 72 73 2e 41 64 64 28 22 24 55 73 65 72 6e  ters.Add("$Usern
20b0: 61 6d 65 22 2c 20 44 62 54 79 70 65 2e 53 74 72  ame", DbType.Str
20c0: 69 6e 67 29 2e 56 61 6c 75 65 20 3d 20 75 73 65  ing).Value = use
20d0: 72 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 20  rname;.         
20e0: 20 20 20 63 6d 64 2e 50 61 72 61 6d 65 74 65 72     cmd.Parameter
20f0: 73 2e 41 64 64 28 22 24 41 70 70 49 44 22 2c 20  s.Add("$AppID", 
2100: 44 62 54 79 70 65 2e 49 6e 74 36 34 29 2e 56 61  DbType.Int64).Va
2110: 6c 75 65 20 3d 20 5f 41 70 70 49 44 3b 0a 0a 20  lue = _AppID;.. 
2120: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74             SQLit
2130: 65 44 61 74 61 52 65 61 64 65 72 20 72 65 61 64  eDataReader read
2140: 65 72 20 3d 20 6e 75 6c 6c 3b 0a 0a 20 20 20 20  er = null;..    
2150: 20 20 20 20 20 20 20 20 74 72 79 0a 20 20 20 20          try.    
2160: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
2170: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 2e 4f            conn.O
2180: 70 65 6e 28 29 3b 0a 0a 20 20 20 20 20 20 20 20  pen();..        
2190: 20 20 20 20 20 20 20 20 72 65 61 64 65 72 20 3d          reader =
21a0: 20 63 6d 64 2e 45 78 65 63 75 74 65 52 65 61 64   cmd.ExecuteRead
21b0: 65 72 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  er();..         
21c0: 20 20 20 20 20 20 20 77 68 69 6c 65 20 28 72 65         while (re
21d0: 61 64 65 72 2e 52 65 61 64 28 29 29 0a 20 20 20  ader.Read()).   
21e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20               {. 
21f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2200: 20 20 20 72 6f 6c 65 73 2e 41 64 64 28 72 65 61     roles.Add(rea
2210: 64 65 72 2e 47 65 74 53 74 72 69 6e 67 28 30 29  der.GetString(0)
2220: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
2230: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
2240: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63   }.            c
2250: 61 74 63 68 20 28 53 51 4c 69 74 65 45 78 63 65  atch (SQLiteExce
2260: 70 74 69 6f 6e 20 65 29 0a 20 20 20 20 20 20 20  ption e).       
2270: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
2280: 20 20 20 20 20 20 20 50 72 6f 76 69 64 65 72 55         ProviderU
2290: 74 69 6c 69 74 79 2e 48 61 6e 64 6c 65 45 78 63  tility.HandleExc
22a0: 65 70 74 69 6f 6e 28 65 2c 20 65 76 65 6e 74 53  eption(e, eventS
22b0: 6f 75 72 63 65 2c 20 22 47 65 74 52 6f 6c 65 73  ource, "GetRoles
22c0: 46 6f 72 55 73 65 72 22 2c 20 57 72 69 74 65 45  ForUser", WriteE
22d0: 78 63 65 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74  xceptionsToEvent
22e0: 4c 6f 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20  Log);.          
22f0: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
2300: 66 69 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20  finally.        
2310: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
2320: 20 20 20 20 20 20 69 66 20 28 72 65 61 64 65 72        if (reader
2330: 20 21 3d 20 6e 75 6c 6c 29 20 7b 20 72 65 61 64   != null) { read
2340: 65 72 2e 43 6c 6f 73 65 28 29 3b 20 7d 0a 20 20  er.Close(); }.  
2350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f                co
2360: 6e 6e 2e 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20  nn.Close();.    
2370: 20 20 20 20 20 20 20 20 7d 0a 0a 0a 20 20 20 20          }...    
2380: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 72          return r
2390: 6f 6c 65 73 2e 54 6f 41 72 72 61 79 28 29 3b 0a  oles.ToArray();.
23a0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
23b0: 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64    public overrid
23c0: 65 20 73 74 72 69 6e 67 5b 5d 20 47 65 74 55 73  e string[] GetUs
23d0: 65 72 73 49 6e 52 6f 6c 65 28 73 74 72 69 6e 67  ersInRole(string
23e0: 20 72 6f 6c 65 6e 61 6d 65 29 0a 20 20 20 20 20   rolename).     
23f0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
2400: 20 4c 69 73 74 3c 53 74 72 69 6e 67 3e 20 75 73   List<String> us
2410: 65 72 73 20 3d 20 6e 65 77 20 4c 69 73 74 3c 73  ers = new List<s
2420: 74 72 69 6e 67 3e 28 29 3b 0a 0a 20 20 20 20 20  tring>();..     
2430: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e         SQLiteCon
2440: 6e 65 63 74 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e  nection conn = n
2450: 65 77 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74  ew SQLiteConnect
2460: 69 6f 6e 28 63 6f 6e 6e 65 63 74 69 6f 6e 53 74  ion(connectionSt
2470: 72 69 6e 67 29 3b 0a 20 20 20 20 20 20 20 20 20  ring);.         
2480: 20 20 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64     SQLiteCommand
2490: 20 63 6d 64 20 3d 20 6e 65 77 20 53 51 4c 69 74   cmd = new SQLit
24a0: 65 43 6f 6d 6d 61 6e 64 28 52 6f 6c 65 53 71 6c  eCommand(RoleSql
24b0: 2e 47 65 74 55 73 65 72 73 49 6e 52 6f 6c 65 2c  .GetUsersInRole,
24c0: 20 63 6f 6e 6e 29 3b 0a 0a 20 20 20 20 20 20 20   conn);..       
24d0: 20 20 20 20 20 63 6d 64 2e 50 61 72 61 6d 65 74       cmd.Paramet
24e0: 65 72 73 2e 41 64 64 28 22 24 52 6f 6c 65 6e 61  ers.Add("$Rolena
24f0: 6d 65 22 2c 20 44 62 54 79 70 65 2e 53 74 72 69  me", DbType.Stri
2500: 6e 67 29 2e 56 61 6c 75 65 20 3d 20 72 6f 6c 65  ng).Value = role
2510: 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 20 20  name;.          
2520: 20 20 63 6d 64 2e 50 61 72 61 6d 65 74 65 72 73    cmd.Parameters
2530: 2e 41 64 64 28 22 24 41 70 70 49 44 22 2c 20 44  .Add("$AppID", D
2540: 62 54 79 70 65 2e 49 6e 74 36 34 29 2e 56 61 6c  bType.Int64).Val
2550: 75 65 20 3d 20 5f 41 70 70 49 44 3b 0a 0a 20 20  ue = _AppID;..  
2560: 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65            SQLite
2570: 44 61 74 61 52 65 61 64 65 72 20 72 65 61 64 65  DataReader reade
2580: 72 20 3d 20 6e 75 6c 6c 3b 0a 0a 20 20 20 20 20  r = null;..     
2590: 20 20 20 20 20 20 20 74 72 79 0a 20 20 20 20 20         try.     
25a0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
25b0: 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 2e 4f 70           conn.Op
25c0: 65 6e 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  en();..         
25d0: 20 20 20 20 20 20 20 72 65 61 64 65 72 20 3d 20         reader = 
25e0: 63 6d 64 2e 45 78 65 63 75 74 65 52 65 61 64 65  cmd.ExecuteReade
25f0: 72 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20  r();..          
2600: 20 20 20 20 20 20 77 68 69 6c 65 20 28 72 65 61        while (rea
2610: 64 65 72 2e 52 65 61 64 28 29 29 0a 20 20 20 20  der.Read()).    
2620: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20              {.  
2630: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2640: 20 20 75 73 65 72 73 2e 41 64 64 28 72 65 61 64    users.Add(read
2650: 65 72 2e 47 65 74 53 74 72 69 6e 67 28 30 29 29  er.GetString(0))
2660: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
2670: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
2680: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 61  }.            ca
2690: 74 63 68 20 28 53 51 4c 69 74 65 45 78 63 65 70  tch (SQLiteExcep
26a0: 74 69 6f 6e 20 65 29 0a 20 20 20 20 20 20 20 20  tion e).        
26b0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
26c0: 20 20 20 20 20 20 50 72 6f 76 69 64 65 72 55 74        ProviderUt
26d0: 69 6c 69 74 79 2e 48 61 6e 64 6c 65 45 78 63 65  ility.HandleExce
26e0: 70 74 69 6f 6e 28 65 2c 20 65 76 65 6e 74 53 6f  ption(e, eventSo
26f0: 75 72 63 65 2c 20 22 47 65 74 55 73 65 72 73 49  urce, "GetUsersI
2700: 6e 52 6f 6c 65 22 2c 20 57 72 69 74 65 45 78 63  nRole", WriteExc
2710: 65 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f  eptionsToEventLo
2720: 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  g);.            
2730: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 69  }.            fi
2740: 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20 20  nally.          
2750: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
2760: 20 20 20 20 69 66 20 28 72 65 61 64 65 72 20 21      if (reader !
2770: 3d 20 6e 75 6c 6c 29 20 7b 20 72 65 61 64 65 72  = null) { reader
2780: 2e 43 6c 6f 73 65 28 29 3b 20 7d 0a 20 20 20 20  .Close(); }.    
2790: 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e 6e              conn
27a0: 2e 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20 20 20  .Close();.      
27b0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
27c0: 20 20 20 20 72 65 74 75 72 6e 20 75 73 65 72 73      return users
27d0: 2e 54 6f 41 72 72 61 79 28 29 3b 0a 20 20 20 20  .ToArray();.    
27e0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 70 75      }.        pu
27f0: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62 6f  blic override bo
2800: 6f 6c 20 49 73 55 73 65 72 49 6e 52 6f 6c 65 28  ol IsUserInRole(
2810: 73 74 72 69 6e 67 20 75 73 65 72 6e 61 6d 65 2c  string username,
2820: 20 73 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d 65   string rolename
2830: 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20  ).        {.    
2840: 20 20 20 20 20 20 20 20 6c 6f 6e 67 20 63 6f 75          long cou
2850: 6e 74 20 3d 20 30 3b 0a 0a 20 20 20 20 20 20 20  nt = 0;..       
2860: 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65       SQLiteConne
2870: 63 74 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e 65 77  ction conn = new
2880: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
2890: 6e 28 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69  n(connectionStri
28a0: 6e 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  ng);.           
28b0: 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63   SQLiteCommand c
28c0: 6d 64 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43  md = new SQLiteC
28d0: 6f 6d 6d 61 6e 64 28 52 6f 6c 65 53 71 6c 2e 49  ommand(RoleSql.I
28e0: 73 55 73 65 72 49 6e 52 6f 6c 65 2c 20 63 6f 6e  sUserInRole, con
28f0: 6e 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20  n);..           
2900: 20 63 6d 64 2e 50 61 72 61 6d 65 74 65 72 73 2e   cmd.Parameters.
2910: 41 64 64 28 22 24 55 73 65 72 6e 61 6d 65 22 2c  Add("$Username",
2920: 20 44 62 54 79 70 65 2e 53 74 72 69 6e 67 29 2e   DbType.String).
2930: 56 61 6c 75 65 20 3d 20 75 73 65 72 6e 61 6d 65  Value = username
2940: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6d  ;.            cm
2950: 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41 64 64  d.Parameters.Add
2960: 28 22 24 52 6f 6c 65 6e 61 6d 65 22 2c 20 44 62  ("$Rolename", Db
2970: 54 79 70 65 2e 53 74 72 69 6e 67 29 2e 56 61 6c  Type.String).Val
2980: 75 65 20 3d 20 72 6f 6c 65 6e 61 6d 65 3b 0a 20  ue = rolename;. 
2990: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 50             cmd.P
29a0: 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 22 24  arameters.Add("$
29b0: 41 70 70 49 44 22 2c 20 44 62 54 79 70 65 2e 49  AppID", DbType.I
29c0: 6e 74 36 34 29 2e 56 61 6c 75 65 20 3d 20 5f 41  nt64).Value = _A
29d0: 70 70 49 44 3b 0a 0a 20 20 20 20 20 20 20 20 20  ppID;..         
29e0: 20 20 20 74 72 79 0a 20 20 20 20 20 20 20 20 20     try.         
29f0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
2a00: 20 20 20 20 20 63 6f 6e 6e 2e 4f 70 65 6e 28 29       conn.Open()
2a10: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
2a20: 20 20 63 6f 75 6e 74 20 3d 20 28 6c 6f 6e 67 29    count = (long)
2a30: 63 6d 64 2e 45 78 65 63 75 74 65 53 63 61 6c 61  cmd.ExecuteScala
2a40: 72 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  r();.           
2a50: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63   }.            c
2a60: 61 74 63 68 20 28 53 51 4c 69 74 65 45 78 63 65  atch (SQLiteExce
2a70: 70 74 69 6f 6e 20 65 29 0a 20 20 20 20 20 20 20  ption e).       
2a80: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
2a90: 20 20 20 20 20 20 20 50 72 6f 76 69 64 65 72 55         ProviderU
2aa0: 74 69 6c 69 74 79 2e 48 61 6e 64 6c 65 45 78 63  tility.HandleExc
2ab0: 65 70 74 69 6f 6e 28 65 2c 20 65 76 65 6e 74 53  eption(e, eventS
2ac0: 6f 75 72 63 65 2c 20 22 49 73 55 73 65 72 49 6e  ource, "IsUserIn
2ad0: 52 6f 6c 65 22 2c 20 57 72 69 74 65 45 78 63 65  Role", WriteExce
2ae0: 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67  ptionsToEventLog
2af0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  );.            }
2b00: 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 69 6e  .            fin
2b10: 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20 20 20  ally.           
2b20: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
2b30: 20 20 20 63 6f 6e 6e 2e 43 6c 6f 73 65 28 29 3b     conn.Close();
2b40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 0a  .            }..
2b50: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
2b60: 72 6e 20 28 63 6f 75 6e 74 20 21 3d 20 30 29 3b  rn (count != 0);
2b70: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
2b80: 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69     public overri
2b90: 64 65 20 76 6f 69 64 20 52 65 6d 6f 76 65 55 73  de void RemoveUs
2ba0: 65 72 73 46 72 6f 6d 52 6f 6c 65 73 28 73 74 72  ersFromRoles(str
2bb0: 69 6e 67 5b 5d 20 75 73 65 72 6e 61 6d 65 73 2c  ing[] usernames,
2bc0: 20 73 74 72 69 6e 67 5b 5d 20 72 6f 6c 65 6e 61   string[] rolena
2bd0: 6d 65 73 29 0a 20 20 20 20 20 20 20 20 7b 0a 20  mes).        {. 
2be0: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61             forea
2bf0: 63 68 20 28 73 74 72 69 6e 67 20 72 6f 6c 65 6e  ch (string rolen
2c00: 61 6d 65 20 69 6e 20 72 6f 6c 65 6e 61 6d 65 73  ame in rolenames
2c10: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a  ).            {.
2c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c30: 69 66 20 28 21 52 6f 6c 65 45 78 69 73 74 73 28  if (!RoleExists(
2c40: 72 6f 6c 65 6e 61 6d 65 29 29 0a 20 20 20 20 20  rolename)).     
2c50: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
2c60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c70: 20 74 68 72 6f 77 20 6e 65 77 20 50 72 6f 76 69   throw new Provi
2c80: 64 65 72 45 78 63 65 70 74 69 6f 6e 28 22 52 6f  derException("Ro
2c90: 6c 65 20 6e 61 6d 65 20 6e 6f 74 20 66 6f 75 6e  le name not foun
2ca0: 64 2e 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20  d.");.          
2cb0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
2cc0: 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 20      }..         
2cd0: 20 20 20 66 6f 72 65 61 63 68 20 28 73 74 72 69     foreach (stri
2ce0: 6e 67 20 75 73 65 72 6e 61 6d 65 20 69 6e 20 75  ng username in u
2cf0: 73 65 72 6e 61 6d 65 73 29 0a 20 20 20 20 20 20  sernames).      
2d00: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
2d10: 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 68 20          foreach 
2d20: 28 73 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d 65  (string rolename
2d30: 20 69 6e 20 72 6f 6c 65 6e 61 6d 65 73 29 0a 20   in rolenames). 
2d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
2d50: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2d60: 20 20 20 20 20 69 66 20 28 21 49 73 55 73 65 72       if (!IsUser
2d70: 49 6e 52 6f 6c 65 28 75 73 65 72 6e 61 6d 65 2c  InRole(username,
2d80: 20 72 6f 6c 65 6e 61 6d 65 29 29 0a 20 20 20 20   rolename)).    
2d90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2da0: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
2db0: 20 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20            throw 
2dc0: 6e 65 77 20 50 72 6f 76 69 64 65 72 45 78 63 65  new ProviderExce
2dd0: 70 74 69 6f 6e 28 22 55 73 65 72 20 69 73 20 6e  ption("User is n
2de0: 6f 74 20 69 6e 20 72 6f 6c 65 2e 22 29 3b 0a 20  ot in role.");. 
2df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e00: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
2e10: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
2e20: 20 20 20 7d 0a 0a 0a 20 20 20 20 20 20 20 20 20     }...         
2e30: 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74     SQLiteConnect
2e40: 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e 65 77 20 53  ion conn = new S
2e50: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 28  QLiteConnection(
2e60: 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e 67  connectionString
2e70: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 53  );.            S
2e80: 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63 6d 64  QLiteCommand cmd
2e90: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6d   = new SQLiteCom
2ea0: 6d 61 6e 64 28 52 6f 6c 65 53 71 6c 2e 44 65 6c  mand(RoleSql.Del
2eb0: 65 74 65 55 73 65 72 46 72 6f 6d 52 6f 6c 65 2c  eteUserFromRole,
2ec0: 20 63 6f 6e 6e 29 3b 0a 0a 20 20 20 20 20 20 20   conn);..       
2ed0: 20 20 20 20 20 53 51 4c 69 74 65 50 61 72 61 6d       SQLiteParam
2ee0: 65 74 65 72 20 75 73 65 72 50 61 72 6d 20 3d 20  eter userParm = 
2ef0: 63 6d 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41  cmd.Parameters.A
2f00: 64 64 28 22 24 55 73 65 72 6e 61 6d 65 22 2c 20  dd("$Username", 
2f10: 44 62 54 79 70 65 2e 53 74 72 69 6e 67 29 3b 0a  DbType.String);.
2f20: 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69              SQLi
2f30: 74 65 50 61 72 61 6d 65 74 65 72 20 72 6f 6c 65  teParameter role
2f40: 50 61 72 6d 20 3d 20 63 6d 64 2e 50 61 72 61 6d  Parm = cmd.Param
2f50: 65 74 65 72 73 2e 41 64 64 28 22 24 52 6f 6c 65  eters.Add("$Role
2f60: 6e 61 6d 65 22 2c 20 44 62 54 79 70 65 2e 53 74  name", DbType.St
2f70: 72 69 6e 67 29 3b 0a 20 20 20 20 20 20 20 20 20  ring);.         
2f80: 20 20 20 63 6d 64 2e 50 61 72 61 6d 65 74 65 72     cmd.Parameter
2f90: 73 2e 41 64 64 28 22 24 41 70 70 49 44 22 2c 20  s.Add("$AppID", 
2fa0: 44 62 54 79 70 65 2e 49 6e 74 36 34 29 2e 56 61  DbType.Int64).Va
2fb0: 6c 75 65 20 3d 20 5f 41 70 70 49 44 3b 0a 0a 20  lue = _AppID;.. 
2fc0: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74             SQLit
2fd0: 65 54 72 61 6e 73 61 63 74 69 6f 6e 20 74 72 61  eTransaction tra
2fe0: 6e 20 3d 20 6e 75 6c 6c 3b 0a 0a 20 20 20 20 20  n = null;..     
2ff0: 20 20 20 20 20 20 20 74 72 79 0a 20 20 20 20 20         try.     
3000: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
3010: 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 2e 4f 70           conn.Op
3020: 65 6e 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20  en();.          
3030: 20 20 20 20 20 20 74 72 61 6e 20 3d 20 63 6f 6e        tran = con
3040: 6e 2e 42 65 67 69 6e 54 72 61 6e 73 61 63 74 69  n.BeginTransacti
3050: 6f 6e 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20  on();.          
3060: 20 20 20 20 20 20 63 6d 64 2e 54 72 61 6e 73 61        cmd.Transa
3070: 63 74 69 6f 6e 20 3d 20 74 72 61 6e 3b 0a 0a 20  ction = tran;.. 
3080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66                 f
3090: 6f 72 65 61 63 68 20 28 73 74 72 69 6e 67 20 75  oreach (string u
30a0: 73 65 72 6e 61 6d 65 20 69 6e 20 75 73 65 72 6e  sername in usern
30b0: 61 6d 65 73 29 0a 20 20 20 20 20 20 20 20 20 20  ames).          
30c0: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
30d0: 20 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65              fore
30e0: 61 63 68 20 28 73 74 72 69 6e 67 20 72 6f 6c 65  ach (string role
30f0: 6e 61 6d 65 20 69 6e 20 72 6f 6c 65 6e 61 6d 65  name in rolename
3100: 73 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  s).             
3110: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
3120: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3130: 20 75 73 65 72 50 61 72 6d 2e 56 61 6c 75 65 20   userParm.Value 
3140: 3d 20 75 73 65 72 6e 61 6d 65 3b 0a 20 20 20 20  = username;.    
3150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3160: 20 20 20 20 72 6f 6c 65 50 61 72 6d 2e 56 61 6c      roleParm.Val
3170: 75 65 20 3d 20 72 6f 6c 65 6e 61 6d 65 3b 0a 20  ue = rolename;. 
3180: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3190: 20 20 20 20 20 20 20 63 6d 64 2e 45 78 65 63 75         cmd.Execu
31a0: 74 65 4e 6f 6e 51 75 65 72 79 28 29 3b 0a 20 20  teNonQuery();.  
31b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
31c0: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
31d0: 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 20      }..         
31e0: 20 20 20 20 20 20 20 74 72 61 6e 2e 43 6f 6d 6d         tran.Comm
31f0: 69 74 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20  it();.          
3200: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
3210: 63 61 74 63 68 20 28 53 51 4c 69 74 65 45 78 63  catch (SQLiteExc
3220: 65 70 74 69 6f 6e 20 65 29 0a 20 20 20 20 20 20  eption e).      
3230: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
3240: 20 20 20 20 20 20 20 20 74 72 79 0a 20 20 20 20          try.    
3250: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20              {.  
3260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3270: 20 20 74 72 61 6e 2e 52 6f 6c 6c 62 61 63 6b 28    tran.Rollback(
3280: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
3290: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
32a0: 20 20 20 20 20 63 61 74 63 68 20 7b 20 7d 0a 20       catch { }. 
32b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 50                 P
32c0: 72 6f 76 69 64 65 72 55 74 69 6c 69 74 79 2e 48  roviderUtility.H
32d0: 61 6e 64 6c 65 45 78 63 65 70 74 69 6f 6e 28 65  andleException(e
32e0: 2c 20 65 76 65 6e 74 53 6f 75 72 63 65 2c 20 22  , eventSource, "
32f0: 52 65 6d 6f 76 65 55 73 65 72 73 46 72 6f 6d 52  RemoveUsersFromR
3300: 6f 6c 65 73 22 2c 20 57 72 69 74 65 45 78 63 65  oles", WriteExce
3310: 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67  ptionsToEventLog
3320: 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
3330: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 69  }.            fi
3340: 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20 20  nally.          
3350: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
3360: 20 20 20 20 63 6f 6e 6e 2e 43 6c 6f 73 65 28 29      conn.Close()
3370: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a  ;.            }.
3380: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3390: 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64    public overrid
33a0: 65 20 62 6f 6f 6c 20 52 6f 6c 65 45 78 69 73 74  e bool RoleExist
33b0: 73 28 73 74 72 69 6e 67 20 72 6f 6c 65 6e 61 6d  s(string rolenam
33c0: 65 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  e).        {.   
33d0: 20 20 20 20 20 20 20 20 20 6c 6f 6e 67 20 63 6f           long co
33e0: 75 6e 74 20 3d 20 30 3b 0a 0a 20 20 20 20 20 20  unt = 0;..      
33f0: 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e        SQLiteConn
3400: 65 63 74 69 6f 6e 20 63 6f 6e 6e 20 3d 20 6e 65  ection conn = ne
3410: 77 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  w SQLiteConnecti
3420: 6f 6e 28 63 6f 6e 6e 65 63 74 69 6f 6e 53 74 72  on(connectionStr
3430: 69 6e 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20  ing);.          
3440: 20 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20    SQLiteCommand 
3450: 63 6d 64 20 3d 20 6e 65 77 20 53 51 4c 69 74 65  cmd = new SQLite
3460: 43 6f 6d 6d 61 6e 64 28 52 6f 6c 65 53 71 6c 2e  Command(RoleSql.
3470: 52 6f 6c 65 45 78 69 73 74 73 2c 20 63 6f 6e 6e  RoleExists, conn
3480: 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
3490: 63 6d 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41  cmd.Parameters.A
34a0: 64 64 28 22 24 52 6f 6c 65 6e 61 6d 65 22 2c 20  dd("$Rolename", 
34b0: 44 62 54 79 70 65 2e 53 74 72 69 6e 67 29 2e 56  DbType.String).V
34c0: 61 6c 75 65 20 3d 20 72 6f 6c 65 6e 61 6d 65 3b  alue = rolename;
34d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6d 64  .            cmd
34e0: 2e 50 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28  .Parameters.Add(
34f0: 22 24 41 70 70 49 44 22 2c 20 44 62 54 79 70 65  "$AppID", DbType
3500: 2e 49 6e 74 36 34 29 2e 56 61 6c 75 65 20 3d 20  .Int64).Value = 
3510: 5f 41 70 70 49 44 3b 0a 0a 20 20 20 20 20 20 20  _AppID;..       
3520: 20 20 20 20 20 74 72 79 0a 20 20 20 20 20 20 20       try.       
3530: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
3540: 20 20 20 20 20 20 20 63 6f 6e 6e 2e 4f 70 65 6e         conn.Open
3550: 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ();.            
3560: 20 20 20 20 63 6f 75 6e 74 20 3d 20 28 6c 6f 6e      count = (lon
3570: 67 29 63 6d 64 2e 45 78 65 63 75 74 65 53 63 61  g)cmd.ExecuteSca
3580: 6c 61 72 28 29 3b 0a 20 20 20 20 20 20 20 20 20  lar();.         
3590: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
35a0: 20 63 61 74 63 68 20 28 53 51 4c 69 74 65 45 78   catch (SQLiteEx
35b0: 63 65 70 74 69 6f 6e 20 65 29 0a 20 20 20 20 20  ception e).     
35c0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
35d0: 20 20 20 20 20 20 20 20 20 50 72 6f 76 69 64 65           Provide
35e0: 72 55 74 69 6c 69 74 79 2e 48 61 6e 64 6c 65 45  rUtility.HandleE
35f0: 78 63 65 70 74 69 6f 6e 28 65 2c 20 65 76 65 6e  xception(e, even
3600: 74 53 6f 75 72 63 65 2c 20 22 52 6f 6c 65 45 78  tSource, "RoleEx
3610: 69 73 74 73 22 2c 20 57 72 69 74 65 45 78 63 65  ists", WriteExce
3620: 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f 67  ptionsToEventLog
3630: 29 3b 0a 0a 0a 20 20 20 20 20 20 20 20 20 20 20  );...           
3640: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 66   }.            f
3650: 69 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20  inally.         
3660: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
3670: 20 20 20 20 20 63 6f 6e 6e 2e 43 6c 6f 73 65 28       conn.Close(
3680: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  );.            }
3690: 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ..            re
36a0: 74 75 72 6e 20 28 63 6f 75 6e 74 20 21 3d 20 30  turn (count != 0
36b0: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
36c0: 20 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72       public over
36d0: 72 69 64 65 20 73 74 72 69 6e 67 5b 5d 20 46 69  ride string[] Fi
36e0: 6e 64 55 73 65 72 73 49 6e 52 6f 6c 65 28 73 74  ndUsersInRole(st
36f0: 72 69 6e 67 20 72 6f 6c 65 6e 61 6d 65 2c 20 73  ring rolename, s
3700: 74 72 69 6e 67 20 75 73 65 72 6e 61 6d 65 54 6f  tring usernameTo
3710: 4d 61 74 63 68 29 0a 20 20 20 20 20 20 20 20 7b  Match).        {
3720: 0a 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c  .            SQL
3730: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6f  iteConnection co
3740: 6e 6e 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43  nn = new SQLiteC
3750: 6f 6e 6e 65 63 74 69 6f 6e 28 63 6f 6e 6e 65 63  onnection(connec
3760: 74 69 6f 6e 53 74 72 69 6e 67 29 3b 0a 20 20 20  tionString);.   
3770: 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43           SQLiteC
3780: 6f 6d 6d 61 6e 64 20 63 6d 64 20 3d 20 6e 65 77  ommand cmd = new
3790: 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 28 52   SQLiteCommand(R
37a0: 6f 6c 65 53 71 6c 2e 46 69 6e 64 55 73 65 72 73  oleSql.FindUsers
37b0: 49 6e 52 6f 6c 65 2c 20 63 6f 6e 6e 29 3b 0a 20  InRole, conn);. 
37c0: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 50             cmd.P
37d0: 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 22 24  arameters.Add("$
37e0: 55 73 65 72 6e 61 6d 65 22 2c 20 44 62 54 79 70  Username", DbTyp
37f0: 65 2e 53 74 72 69 6e 67 29 2e 56 61 6c 75 65 20  e.String).Value 
3800: 3d 20 75 73 65 72 6e 61 6d 65 54 6f 4d 61 74 63  = usernameToMatc
3810: 68 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 63  h;.            c
3820: 6d 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41 64  md.Parameters.Ad
3830: 64 28 22 24 52 6f 6c 65 6e 61 6d 65 22 2c 20 44  d("$Rolename", D
3840: 62 54 79 70 65 2e 53 74 72 69 6e 67 29 2e 56 61  bType.String).Va
3850: 6c 75 65 20 3d 20 72 6f 6c 65 6e 61 6d 65 3b 0a  lue = rolename;.
3860: 20 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e              cmd.
3870: 50 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 22  Parameters.Add("
3880: 24 41 70 70 49 44 22 2c 20 44 62 54 79 70 65 2e  $AppID", DbType.
3890: 49 6e 74 36 34 29 2e 56 61 6c 75 65 20 3d 20 5f  Int64).Value = _
38a0: 41 70 70 49 44 3b 0a 0a 20 20 20 20 20 20 20 20  AppID;..        
38b0: 20 20 20 20 4c 69 73 74 3c 53 74 72 69 6e 67 3e      List<String>
38c0: 20 75 73 65 72 73 20 3d 20 6e 65 77 20 4c 69 73   users = new Lis
38d0: 74 3c 73 74 72 69 6e 67 3e 28 29 3b 0a 20 20 20  t<string>();.   
38e0: 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 44           SQLiteD
38f0: 61 74 61 52 65 61 64 65 72 20 72 65 61 64 65 72  ataReader reader
3900: 20 3d 20 6e 75 6c 6c 3b 0a 0a 20 20 20 20 20 20   = null;..      
3910: 20 20 20 20 20 20 74 72 79 0a 20 20 20 20 20 20        try.      
3920: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
3930: 20 20 20 20 20 20 20 20 63 6f 6e 6e 2e 4f 70 65          conn.Ope
3940: 6e 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20  n();..          
3950: 20 20 20 20 20 20 72 65 61 64 65 72 20 3d 20 63        reader = c
3960: 6d 64 2e 45 78 65 63 75 74 65 52 65 61 64 65 72  md.ExecuteReader
3970: 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20  ();..           
3980: 20 20 20 20 20 77 68 69 6c 65 20 28 72 65 61 64       while (read
3990: 65 72 2e 52 65 61 64 28 29 29 0a 20 20 20 20 20  er.Read()).     
39a0: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
39b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
39c0: 20 75 73 65 72 73 2e 41 64 64 28 72 65 61 64 65   users.Add(reade
39d0: 72 2e 47 65 74 53 74 72 69 6e 67 28 30 29 29 3b  r.GetString(0));
39e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
39f0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d   }.            }
3a00: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 61 74  .            cat
3a10: 63 68 20 28 53 51 4c 69 74 65 45 78 63 65 70 74  ch (SQLiteExcept
3a20: 69 6f 6e 20 65 29 0a 20 20 20 20 20 20 20 20 20  ion e).         
3a30: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
3a40: 20 20 20 20 20 50 72 6f 76 69 64 65 72 55 74 69       ProviderUti
3a50: 6c 69 74 79 2e 48 61 6e 64 6c 65 45 78 63 65 70  lity.HandleExcep
3a60: 74 69 6f 6e 28 65 2c 20 65 76 65 6e 74 53 6f 75  tion(e, eventSou
3a70: 72 63 65 2c 20 22 46 69 6e 64 55 73 65 72 73 49  rce, "FindUsersI
3a80: 6e 52 6f 6c 65 22 2c 20 57 72 69 74 65 45 78 63  nRole", WriteExc
3a90: 65 70 74 69 6f 6e 73 54 6f 45 76 65 6e 74 4c 6f  eptionsToEventLo
3aa0: 67 29 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  g);             
3ab0: 20 20 20 0a 0a 20 20 20 20 20 20 20 20 20 20 20     ..           
3ac0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 66   }.            f
3ad0: 69 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20  inally.         
3ae0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
3af0: 20 20 20 20 20 69 66 20 28 72 65 61 64 65 72 20       if (reader 
3b00: 21 3d 20 6e 75 6c 6c 29 20 7b 20 72 65 61 64 65  != null) { reade
3b10: 72 2e 43 6c 6f 73 65 28 29 3b 20 7d 0a 0a 20 20  r.Close(); }..  
3b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f                co
3b30: 6e 6e 2e 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20  nn.Close();.    
3b40: 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20          }..     
3b50: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 75 73         return us
3b60: 65 72 73 2e 54 6f 41 72 72 61 79 28 29 3b 0a 20  ers.ToArray();. 
3b70: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 7d 0a         }..    }.
3b80: 7d 0a 0a 0a                                      }...