/* Domain Lord Access Control Object */ /* As domain lord you have access control to files in your domain. * You have access to all your domain files. Using the 'domain' command you * can add more creators to your domain. You can set up your own hierachy * of creators if you wish. It is important to note that you have complete * control. You can block as well as give access. Only Arches, and you can * can add new creator directories (through the 'domain' cmd). Only the * highlord of the domain and arches can edit this file. * * A return of 1 will give 'name' access to the file, fname. * A return of 0 will give default access. (I think its sec level 60 * for valid write to d/domain/w/, and sec level 50 for valid_read) */ /* VALID WRITE */ status valid_write(string fname, string name) { string domain, who, file; if(sscanf(fname,"/d/%s/w/%s/%s", domain, who, file) == 3) { if(name == who) return 1; /* owner gets auto access to files */ if(file == "access.c") return 0; /* only let owner edit access ob */ if(call_other("/d/"+domain+"/w/"+who+"/access","valid_write",fname,name)){ return 1; /* owner access ob says they have write access to file */ } } return 0; } /* VALID READ. */ status valid_read(string fname, string name) { string domain, who, file; if(valid_write(fname,name)) return 1; if(sscanf(fname,"/d/%s/w/%s", domain, who)) { if(who == name) return 1; } if(sscanf(fname,"/d/%s/w/%s/%s", domain, who, file) == 3) { if(name == who) return 1; if(call_other("/d/"+domain+"/w/"+who+"/access","valid_read",fname,name)){ return 1; } } return 0; }