#include #include #include #include #include #include <9p.h> #include "cifs.h" struct { /* Well known security IDs */ char *name; char *auth; char *rid; } known[] = { /* default local users */ { "lu.dialup", "S-1-5-1", nil }, { "lu.network", "S-1-5-2", nil }, { "lu.batch", "S-1-5-3", nil }, { "lu.interactive", "S-1-5-4", nil }, { "lu.service", "S-1-5-6", nil }, { "lu.anon", "S-1-5-7", nil }, { "lu.DC", "S-1-5-8", nil }, { "lu.enterprise-domain", "S-1-5-9", nil }, { "lu.self", "S-1-5-10", nil }, { "lu.authenticated", "S-1-5-11", nil }, { "lu.restricted", "S-1-5-12", nil }, { "lu.terminal-services", "S-1-5-13", nil }, { "lu.remote-desktop", "S-1-5-14", nil }, { "lu.local-system", "S-1-5-18", nil }, { "lu.local-service", "S-1-5-19", nil }, { "lu.network-service", "S-1-5-20", nil }, { "lu.builtin", "S-1-5-32", nil }, /* default local groups */ { "lg.null", "S-1-0-0", nil }, { "lg.world", "S-1-1-0", nil }, { "lg.local", "S-1-2-0", nil }, { "lg.creator-owner", "S-1-3-0", nil }, { "lg.creator-group", "S-1-3-1", nil }, { "lg.creator-owner-server", "S-1-3-2", nil }, { "lg.creator-group-server", "S-1-3-3", nil }, /* default domain users */ { "du.admin", "S-1-5", "500" }, { "du.guest", "S-1-5", "501" }, { "du.kerberos", "S-1-5", "502" }, /* default domain groups */ { "dg.admins", "S-1-5-21", "512" }, { "dg.users", "S-1-5-21", "513" }, { "dg.guests", "S-1-5", "514" }, { "dg.computers", "S-1-5", "515" }, { "dg.controllers", "S-1-5", "516" }, { "dg.cert-admins", "S-1-5", "517" }, { "dg.schema-admins", "S-1-5", "518" }, { "dg.enterprise-admins", "S-1-5", "519" }, { "dg.group-policy-admins", "S-1-5", "520" }, { "dg.remote-access", "S-1-5", "553" }, /* default domain aliases */ { "da.admins", "S-1-5", "544" }, { "da.users", "S-1-5", "545" }, { "da.guests", "S-1-5", "546" }, { "da.power-users", "S-1-5", "547" }, { "da.account-operators", "S-1-5", "548" }, { "da.server-operators", "S-1-5", "549" }, { "da.print-operators", "S-1-5", "550" }, { "da.backup-operators", "S-1-5", "551" }, { "da.replicator", "S-1-5", "552" }, { "da.RAS-servers", "S-1-5", "553" }, }; static char * sid2name(char *sid) { int i; char *rid; if(sid == nil || (rid = strrchr(sid, '-')) == nil || *++rid == 0) return estrdup9p("-"); for(i = 0; i < nelem(known); i++){ if(strcmp(known[i].auth, sid) == 0 && known[i].rid == nil) return estrdup9p(known[i].name); if(strlen(known[i].auth) < strlen(sid) && strncmp(known[i].auth, sid, strlen(known[i].auth)) == 0 && known[i].rid && strcmp(known[i].rid, rid) == 0) return estrdup9p(known[i].name); } return estrdup9p(rid); } void upd_names(Session *s, Share *sp, char *path, Dir *d) { int fh, result; char *usid, *gsid; FInfo fi; if(d->uid) free(d->uid); if(d->gid) free(d->gid); if((fh = CIFS_NT_opencreate(s, sp, path, 0, 0, 0, READ_CONTROL, FILE_SHARE_ALL, FILE_OPEN, &result, &fi)) == -1){ d->uid = estrdup9p("unknown"); d->gid = estrdup9p("unknown"); return; } usid = nil; gsid = nil; TNTquerysecurity(s, sp, fh, &usid, &gsid); d->uid = sid2name(usid); d->gid = sid2name(gsid); if(fh != -1) CIFSclose(s, sp, fh); }