X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=citadel%2Fuser_ops.h;h=15107af7db79d1955677fefcfb61f18b37378a52;hb=11e722f9406b58f2884d6d63f4acba49b668f53f;hp=b023eef299209f8d567f4bce48ab0f672ff05b34;hpb=3d120c013c4ffcb4c0f3d23a91d30afddf748c4f;p=citadel.git diff --git a/citadel/user_ops.h b/citadel/user_ops.h index b023eef29..15107af7d 100644 --- a/citadel/user_ops.h +++ b/citadel/user_ops.h @@ -1,78 +1,100 @@ -/* $Id$ */ +#ifndef __USER_OPS_H__ +#define __USER_OPS_H__ + +#include +#include int hash (char *str); -int getuser (struct usersupp *, char *); -int lgetuser (struct usersupp *, char *); -void putuser (struct usersupp *); -void lputuser (struct usersupp *); +/* getuser is deprecated, use CtdlGetUser instead */ +int getuser (struct ctdluser *, char *) __attribute__ ((deprecated)); +/* lgetuser is deprecated, use CtdlGetUserLock instead */ +int lgetuser (struct ctdluser *, char *) __attribute__ ((deprecated)); +/* putuser is deprecated, use CtdlPutUser instead */ +void putuser (struct ctdluser *) __attribute__ ((deprecated)); +/* lputuser is deprecated, use CtdlPutUserLock instead */ +void lputuser (struct ctdluser *) __attribute__ ((deprecated)); int is_aide (void); int is_room_aide (void); -int getuserbynumber (struct usersupp *usbuf, long int number); +/* getuserbynumber is deprecated, use CtdlGetUserByNumber instead */ +int getuserbynumber (struct ctdluser *usbuf, long int number) __attribute__ ((deprecated)); +void rebuild_usersbynumber(void); void cmd_user (char *cmdbuf); void session_startup (void); -void logout (struct CitContext *who); -void cmd_pass (char *buf); +void logged_in_response(void); int purge_user (char *pname); -int create_user (char *newusername); +int create_user (const char *newusername, long len, int become_user); void do_login(void); -void cmd_newu (char *cmdbuf); -void cmd_setp (char *new_pw); -void cmd_getu (void); -void cmd_setu (char *new_parms); -void cmd_slrp (char *new_ptr); -void cmd_invt_kick (char *iuser, int op); -void cmd_forg (void); -void cmd_gnur (void); -void cmd_vali (char *v_args); -void ForEachUser(void (*CallBack)(struct usersupp *EachUser, void *out_data), +int CtdlInvtKick(char *iuser, int op); +void ForEachUser(void (*CallBack)(struct ctdluser *EachUser, void *out_data), void *in_data); -void ListThisUser(struct usersupp *usbuf, void *data); -void cmd_list (void); -void cmd_chek (void); -void cmd_qusr (char *who); -void cmd_agup (char *cmdbuf); -void cmd_asup (char *cmdbuf); +void ListThisUser(struct ctdluser *usbuf, void *data); int NewMailCount(void); -void put_visit(struct visit *newvisit); -void CtdlGetRelationship(struct visit *vbuf, - struct usersupp *rel_user, - struct quickroom *rel_room); -void CtdlSetRelationship(struct visit *newvisit, - struct usersupp *rel_user, - struct quickroom *rel_room); -void MailboxName(char *buf, struct usersupp *who, char *prefix); +int InitialMailCheck(void); +void put_visit(visit *newvisit); +/* MailboxName is deprecated us CtdlMailboxName instead */ +void MailboxName(char *buf, size_t n, const struct ctdluser *who, + const char *prefix) __attribute__ ((deprecated)); int GenerateRelationshipIndex( char *IndexBuf, long RoomID, long RoomGen, long UserID); +int CtdlAssociateSystemUser(char *screenname, char *loginname); -int CtdlLoginExistingUser(char *username); -/* - * Values which may be returned by CtdlLoginExistingUser() - */ -enum { - pass_ok, - pass_already_logged_in, - pass_no_user, - pass_internal_error, - pass_wrong_password -}; +void CtdlSetPassword(char *new_pw); + +int CtdlForgetThisRoom(void); + +void cmd_newu (char *cmdbuf); +void start_chkpwd_daemon(void); + + +#define RENAMEUSER_OK 0 /* Operation succeeded */ +#define RENAMEUSER_LOGGED_IN 1 /* Cannot rename a user who is currently logged in */ +#define RENAMEUSER_NOT_FOUND 2 /* The old user name does not exist */ +#define RENAMEUSER_ALREADY_EXISTS 3 /* An account with the desired new name already exists */ + +int rename_user(char *oldname, char *newname); +///#ifndef CTDL_INLINE_USR +////#define CTDL_INLINE_USR static INLINE +///#endif -int CtdlTryPassword(char *password); +///CTDL_INLINE_USR +static INLINE long cutuserkey(char *username) { + long len; + len = strlen(username); + if (len >= USERNAME_SIZE) + { + syslog(LOG_EMERG, "Username to long: %s", username); + cit_backtrace (); + len = USERNAME_SIZE - 1; + username[len]='\0'; + } + return len; +} /* - * Values which may be returned by CtdlTryPassword() + * makeuserkey() - convert a username into the format used as a database key + * (it's just the username converted into lower case) */ -enum { - login_ok, - login_already_logged_in, - login_too_many_users, - login_not_found -}; +///CTDL_INLINE_USR +static INLINE void makeuserkey(char *key, const char *username, long len) { + int i; + if (len >= USERNAME_SIZE) + { + syslog(LOG_EMERG, "Username to long: %s", username); + cit_backtrace (); + len = USERNAME_SIZE - 1; + } + for (i=0; i<=len; ++i) { + key[i] = tolower(username[i]); + } +} +int internal_create_user (const char *username, long len, struct ctdluser *usbuf, uid_t uid); +#endif