--- libaitcfg/inc/aitpwd.h 2012/09/18 15:50:59 1.1.2.5 +++ libaitcfg/inc/aitpwd.h 2012/09/19 11:47:38 1.1.2.6 @@ -3,7 +3,7 @@ * by Michael Pounov * * $Author: misho $ -* $Id: aitpwd.h,v 1.1.2.5 2012/09/18 15:50:59 misho Exp $ +* $Id: aitpwd.h,v 1.1.2.6 2012/09/19 11:47:38 misho Exp $ * ************************************************************************** The ELWIX and AITNET software is distributed under the following @@ -181,6 +181,16 @@ int cfgWritePasswd(FILE *f, pwd_root_t * __restrict pw int cfgConcatPasswd(pwd_root_t * __restrict pwd, pwd_root_t * __restrict add_pwd); /* + * cfgAuthPasswd() - Authenticate user against passwords db + * + * @pwd = Password root + * @csName = Username + * @csPass = Password + * return: -1 error, 1 deny or 0 allow + */ +int cfgAuthPasswd(pwd_root_t * __restrict pwd, const char *csName, const char *csPass); + +/* * cfg_findPasswdBy() - Find user by criteria position in list * * @pwd = Password root @@ -198,123 +208,35 @@ struct tagUser *cfg_findPasswdBy(pwd_root_t * __restri * return: 0 item not found, -1 error or 1 removed item */ int cfg_unsetPasswd(pwd_root_t * __restrict pwd, int criteria, ...); - -#if 0 /* - * pwdFreeValue() Free passwd_t value - * @ppwd = User object - * @idx = Index of attribute, if ALL == idx is free all structure - * return: 0 ok, -1 error -*/ -inline int pwdFreeValue(passwd_t * __restrict ppwd, passwd_attr_t idx); -/* - * pwdSetValue() Set passwd_t value - * @ppwd = User object - * @idx = Index of attribute, if ALL == idx clean User object and set username! - * @Value = Value to set - * return: number of fields in passwd_t; -1 error:: can`t set passwd_t -*/ -inline int pwdSetValue(passwd_t * __restrict ppwd, passwd_attr_t idx, unsigned char *Value); -/* - * pwdGetValue() Get passwd_t value - * @pwd = User object - * @idx = Index of attribute, if ALL == idx is error! - * @Value = Value to get - * @valLen = Size of Value string - * return: number of fields in passwd_t; -1 error:: can`t get passwd_t -*/ -inline int pwdGetValue(passwd_t __restrict pwd, passwd_attr_t idx, unsigned char *Value, int valLen); - - -/* - * pwd_FindAttribute() Find by attribute position in user array - * @pwd = User array - * @idx = Index of attribute, if ALL == idx return number of user array elements - * @csAttr = User attribute - * return: 0 not found item; -1 error: null parameters; >0 position in array + 1 -*/ -inline int pwd_FindAttribute(passwd_t __restrict pwd, passwd_attr_t idx, const unsigned char *csAttr); -/* - * pwd_SetAttribute() Set user in array or add new user if not exists - * @ppwd = User array - * @idx = Index of attribute to set - * @val = User structure for setup - * return: 0 nothing changed, -1 error: not enough memory; 1 find and update item; 2 added new item -*/ -int pwd_SetAttribute(passwd_t * __restrict ppwd, passwd_attr_t idx, passwd_t val); -/* - * pwd_GetAttribute() Get user from array, set username in val - * @pwd = User array - * @idx = Index of attribute to get, if idx == ALL return full element items - * @val = User structure - * return: 0 not found, -1 error; >0 found at position in array + 1 -*/ -int pwd_GetAttribute(passwd_t __restrict pwd, passwd_attr_t idx, passwd_t val); -/* - * pwd_UnsetAttribute() Unset user from array and free resources! - * @ppwd = User array - * @idx = Index of attribute to unset, if idx == ALL unset(delete) all items in element - * @val = User structure - * return: 0 item not found, -1 error: null parameters; >0 number of elements leave in array -*/ -int pwd_UnsetAttribute(passwd_t * __restrict ppwd, passwd_attr_t idx, passwd_t val); -/* - * pwd_Authenticate() Authenticate user, set username and password in val - * @pwd = User array - * @val = User structure for authenticate, set username & password - after authentication fill other fields if exists - * return: 0 not found, -1 error; >0 found at position in array + 1 -*/ -int pwd_Authenticate(passwd_t __restrict pwd, passwd_t val); - - -/* - * pwd_openAcct() Open accounting aDat binary database - * @csName - DB name - * @minR - Minimum records in database - * @maxR - Maximum records in database(round-robin db), if 0 unlimited grow - * @recSize - Size of record element - * @wrapR - If maxR >0 give ability to wrap round-robin db - * return: NULL error or !=NULL opened db handle + * cfg_setPasswd() - Set item in password or adding new item if not exists + * + * @cfg = Password root + * @csName = Username + * @csPass = Password + * @uid = UID + * @gid = GID + * @Class = Login class + * @change = Chage date + * @expire = Expire date + * @csRealm = Realm + * @csHome = Home dir + * @csShell = Shell + * return: 0 nothing changed, -1 error, 1 found and updated item or 2 added new item */ -struct tagAcctDB *pwd_openAcct(const char *csName, unsigned int minR, unsigned int maxR, - size_t recSize, unsigned char wrapR); +int cfg_setPasswd(pwd_root_t * __restrict pwd, const char *csName, const char *csPass, + unsigned int uid, unsigned int gid, const char *csClass, + unsigned int change, unsigned int expire, const char *csRealm, + const char *csHome, const char *csShell); /* - * pwd_closeAcct() Close accounting aDat binary database - * @db - DB handle - * return: none + * cfg_getPasswd() - Get item from passwords and return structure from it + * + * @pwd = Password root + * @criteria = Search criteria [PWD_CRIT_NAME|PWD_CRIT_UID] + * @arg1 = Username | UID + * return: NULL item not found, !=NULL structure found */ -void pwd_closeAcct(struct tagAcctDB ** __restrict db); -/* - * pwd_writeAcct() Write accounting record to aDat binary database - * @db - DB handle - * @posR - At position number, if db is unlimited grow (-1) write at last free record - * @rec - Record data - * return: -1 error or 0 ok - */ -int pwd_writeAcct(struct tagAcctDB * __restrict db, unsigned int posR, void *rec); -/* - * pwd_readAcct() Read accounting record from aDat binary database - * @db - DB handle - * @posR - From position number - * @rec - Record data buffer - * @recsize - Record data buffer size - * return: -1 error or 0 ok - */ -int pwd_readAcct(struct tagAcctDB * __restrict db, unsigned int posR, void *rec, int recsize); - -/* - * pwd_findAcct() Find accounting record from aDat binary database - * @db - DB handle - * @from - From position - * @to - To position, if 0 search to end-of-file - * @func - Check for match callback function - * @arg - Argument passthrough to callback as argument for search - * return: -1 error, 0 not found or >1 founded at position! (p.s:start from 1) - */ -int64_t pwd_findAcct(struct tagAcctDB * __restrict db, unsigned int from, unsigned int to, - cb_acct_f func, void *arg); -#endif +inline const struct tagUser *cfg_getPasswd(pwd_root_t * __restrict pwd, int criteria, ...); #endif