/*
Unix SMB/CIFS implementation.
Translate unix-defined names to SIDs and vice versa
Copyright (C) Volker Lendecke 2005
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
#include "includes.h"
#include "system/passwd.h"
#include "../libcli/security/security.h"
#include "../lib/util/util_pw.h"
bool sid_check_is_unix_users(const struct dom_sid *sid)
{
return dom_sid_equal(sid, &global_sid_Unix_Users);
}
bool sid_check_is_in_unix_users(const struct dom_sid *sid)
{
struct dom_sid dom_sid;
sid_copy(&dom_sid, sid);
sid_split_rid(&dom_sid, NULL);
return sid_check_is_unix_users(&dom_sid);
}
void uid_to_unix_users_sid(uid_t uid, struct dom_sid *sid)
{
/*
* This can never fail, we know that global_sid_Unix_Users is
* short enough for a domain sid.
*/
sid_compose(sid, &global_sid_Unix_Users, uid);
}
void gid_to_unix_groups_sid(gid_t gid, struct dom_sid *sid)
{
/*
* This can never fail, we know that global_sid_Unix_Groups is
* short enough for a domain sid.
*/
sid_compose(sid, &global_sid_Unix_Groups, gid);
}
const char *unix_users_domain_name(void)
{
return "Unix User";
}
bool lookup_unix_user_name(const char *name, struct dom_sid *sid)
{
struct passwd *pwd;
bool ret;
pwd = Get_Pwnam_alloc(talloc_tos(), name);
if (pwd == NULL) {
return False;
}
/*
* For 64-bit uid's we have enough space in the whole SID,
* should they become necessary
*/
ret = sid_compose(sid, &global_sid_Unix_Users, pwd->pw_uid);
TALLOC_FREE(pwd);
return ret;
}
bool sid_check_is_unix_groups(const struct dom_sid *sid)
{
return dom_sid_equal(sid, &global_sid_Unix_Groups);
}
bool sid_check_is_in_unix_groups(const struct dom_sid *sid)
{
struct dom_sid dom_sid;
sid_copy(&dom_sid, sid);
sid_split_rid(&dom_sid, NULL);
return sid_check_is_unix_groups(&dom_sid);
}
const char *unix_groups_domain_name(void)
{
return "Unix Group";
}
bool lookup_unix_group_name(const char *name, struct dom_sid *sid)
{
struct group *grp;
grp = getgrnam(name);
if (grp == NULL) {
return False;
}
/*
* For 64-bit gid's we have enough space in the whole SID,
* should they become necessary
*/
return sid_compose(sid, &global_sid_Unix_Groups, grp->gr_gid);
}
̹\͌aHmX`}ixV--+#>S:e&|Z6t4#ϡ,@Z0
w8&:t2T$;qf7Wwj郎 imw>vMD}~̺5=Qf5u>kKYv+tOeכ.m4G5F۱I(`TAϓ 34 ~sGHss3wUPQ2Չ; %
m=EUr=ߤG۟#27au#wvUD
)`]2p*ygǤ}Y3!Ȱ%ijiTܫ}70*kCSzR8pͲ>WvXir9Ţen_鱊z,ƒɳfQ's{^i?i&̄J>m Xn}mRv0X%2lQJ"zh`QYh(*yWfaU{Gf?ڥ X@MFp~:cUGq#'a{7;}mh5,-
O8Q[F6>ϻ/bP{6c7l}(y$k?Joi>Eh᳑+/CP=MN/Ջ}~20I4ئX;^zxR/U'羆ejQ tuAӨ!ɬ+ ~l
Mֶ~:tV+l$#F7&L>-I
%3>;}n0Dx84&j};.WOEؐKU!bspHlh K I`1n,d.ynQ
r`/v;#aB9PyEOKxjLϴ'U-/EITxJҠ+[Ԍb~6ۉN٪w:ՔV#a7=7Q.EHL\S),24(9Xr acMiV=c~lhb3=p6cF͜.eXodbAw_.;_e$3fzfvQNmq?q륻:4Uz
W)yYLt
4$o4`d"9
קEC414߭!kgjNYR}vt64 2K$*;$H d4IoZ9kЦg% ,gNj'&6)nndgr[kaCd3MuoM>Iu1*tDF[Nx"7]ﳵEDH/tx.R8J5.N"Q;˄ ZP5<1ُIGnBSvXsU>^gmtN]SM+X q h
cQ69u.6ZiX%Yk<05"Zzٿ]ň+T|sD)