tdaq-develop-2025-02-12
ots::WebUsers Class Reference

#include <otsdaq/WebUsersUtilities/WebUsers.h>

Classes

struct  ActiveSession
 
struct  Hash
 
struct  LoginSession
 
struct  RequestUserInfo
 
struct  SystemMessage
 
struct  User
 

Public Types

enum  {
  SESSION_ID_LENGTH = 512 , COOKIE_CODE_LENGTH = 512 , NOT_FOUND_IN_DATABASE = uint64_t(-1) , ACCOUNT_INACTIVE = uint64_t(-2) ,
  ACCOUNT_BLACKLISTED = uint64_t(-3) , ACCOUNT_ERROR_THRESHOLD = uint64_t(-5) , USERNAME_LENGTH = 3 , DISPLAY_NAME_LENGTH = 4
}
 
enum  { MOD_TYPE_UPDATE , MOD_TYPE_ADD , MOD_TYPE_DELETE }
 
enum  {
  PERMISSION_LEVEL_ADMIN = WebUsers::permissionLevel_t(-1) , PERMISSION_LEVEL_EXPERT = 100 , PERMISSION_LEVEL_USER = 10 , PERMISSION_LEVEL_NOVICE = 1 ,
  PERMISSION_LEVEL_INACTIVE = 0
}
 
enum  { SYS_CLEANUP_WILDCARD_TIME = 300 }
 
using permissionLevel_t = uint8_t
 

Public Member Functions

void addSystemMessage (const std::string &targetUsersCSV, const std::string &message)
 
void addSystemMessage (const std::string &targetUsersCSV, const std::string &subject, const std::string &message, bool doEmail)
 
void addSystemMessage (const std::vector< std::string > &targetUsers, const std::string &subject, const std::string &message, bool doEmail)
 
std::string getSystemMessage (const std::string &targetUser)
 
std::pair< std::string, time_t > getLastSystemMessage (void)
 
std::string getAllSystemMessages (void)
 
bool xmlRequestOnGateway (cgicc::Cgicc &cgi, std::ostringstream *out, HttpXmlDocument *xmldoc, WebUsers::RequestUserInfo &userInfo)
 
void createNewAccount (const std::string &username, const std::string &displayName, const std::string &email)
 
void cleanupExpiredEntries (std::vector< std::string > *loggedOutUsernames=0)
 
void cleanupExpiredRemoteEntries (void)
 
std::string createNewLoginSession (const std::string &uuid, const std::string &ip)
 
uint64_t attemptActiveSession (const std::string &uuid, std::string &jumbledUser, const std::string &jumbledPw, std::string &newAccountCode, const std::string &ip)
 
uint64_t attemptActiveSessionWithCert (const std::string &uuid, std::string &jumbledEmail, std::string &cookieCode, std::string &username, const std::string &ip)
 
uint64_t isCookieCodeActiveForLogin (const std::string &uuid, std::string &cookieCode, std::string &username)
 
bool cookieCodeIsActiveForRequest (std::string &cookieCode, std::map< std::string, WebUsers::permissionLevel_t > *userPermissions=0, uint64_t *uid=0, const std::string &ip="0", bool refresh=true, bool doNotGoRemote=false, std::string *userWithLock=0, uint64_t *userSessionIndex=0)
 
uint64_t cookieCodeLogout (const std::string &cookieCode, bool logoutOtherUserSessions, uint64_t *uid=0, const std::string &ip="0")
 
bool checkIpAccess (const std::string &ip)
 
std::string getUsersDisplayName (uint64_t uid)
 from Gateway, use public version which considers remote users More...
 
std::string getUsersUsername (uint64_t uid)
 from Gateway, use public version which considers remote users More...
 
std::map< std::string, WebUsers::permissionLevel_t > getPermissionsForUser (uint64_t uid)
 from Gateway, use public version which considers remote users More...
 
uint64_t getActiveSessionCountForUser (uint64_t uid)
 
void insertSettingsForUser (uint64_t uid, HttpXmlDocument *xmldoc, bool includeAccounts=false)
 
std::string getGenericPreference (uint64_t uid, const std::string &preferenceName, HttpXmlDocument *xmldoc=0) const
 
void changeSettingsForUser (uint64_t uid, const std::string &bgcolor, const std::string &dbcolor, const std::string &wincolor, const std::string &layout, const std::string &syslayout)
 WebUsers::changeSettingsForUser.
 
void setGenericPreference (uint64_t uid, const std::string &preferenceName, const std::string &preferenceValue)
 
void modifyAccountSettings (uint64_t actingUid, uint8_t cmd_type, const std::string &username, const std::string &displayname, const std::string &email, const std::string &permissions)
 WebUsers::modifyAccountSettings.
 
bool setUserWithLock (uint64_t actingUid, bool lock, const std::string &username)
 
std::string getUserWithLock (void)
 
size_t getActiveUserCount (void)
 
std::string getActiveUsersString (void)
 
bool isUsernameActive (const std::string &username) const
 
bool isUserIdActive (uint64_t uid) const
 
uint64_t getAdminUserID (void)
 
const std::string & getSecurity (void)
 WebUsers::getSecurity.
 
void saveActiveSessions (void)
 
void loadActiveSessions (void)
 

Static Public Member Functions

static void initializeRequestUserInfo (cgicc::Cgicc &cgi, WebUsers::RequestUserInfo &userInfo)
 used by gateway and other supervisors to verify requests consistently More...
 
static bool checkRequestAccess (cgicc::Cgicc &cgi, std::ostringstream *out, HttpXmlDocument *xmldoc, WebUsers::RequestUserInfo &userInfo, bool isWizardMode=false, const std::string &wizardModeSequence="")
 
static void tooltipCheckForUsername (const std::string &username, HttpXmlDocument *xmldoc, const std::string &srcFile, const std::string &srcFunc, const std::string &srcId)
 
static void tooltipSetNeverShowForUsername (const std::string &username, HttpXmlDocument *xmldoc, const std::string &srcFile, const std::string &srcFunc, const std::string &srcId, bool doNeverShow, bool temporarySilence)
 
static void deleteUserData (void)
 
static void resetAllUserTooltips (const std::string &userNeedle="*")
 WebUsers::resetAllUserTooltips.
 
static void silenceAllUserTooltips (const std::string &username)
 
static void NACDisplayThread (const std::string &nac, const std::string &user)
 

Public Attributes

std::atomic< time_t > remoteLoginVerificationEnabledBlackoutTime_ = 0
 
std::string remoteLoginVerificationIP_
 
std::string remoteGatewaySelfName_
 IP of remote Gateway to be used for login verification.
 
int remoteLoginVerificationPort_
 Port of remote Gateway to be used for login verification.
 

Static Public Attributes

static const std::string OTS_OWNER = getenv("OTS_OWNER")?getenv("OTS_OWNER"):""
 defined by environment variable, e.g. experiment name
 
static const std::string DEFAULT_ADMIN_USERNAME = "admin"
 
static const std::string DEFAULT_ADMIN_DISPLAY_NAME = "Administrator"
 
static const std::string DEFAULT_ADMIN_EMAIL = "root@otsdaq.fnal.gov"
 
static const std::string DEFAULT_ITERATOR_USERNAME = "iterator"
 
static const std::string DEFAULT_STATECHANGER_USERNAME = "statechanger"
 
static const std::string DEFAULT_USER_GROUP = "allUsers"
 
static const std::string REQ_NO_LOGIN_RESPONSE = "NoLogin"
 
static const std::string REQ_NO_PERMISSION_RESPONSE = "NoPermission"
 
static const std::string REQ_USER_LOCKOUT_RESPONSE = "UserLockout"
 
static const std::string REQ_LOCK_REQUIRED_RESPONSE = "LockRequired"
 
static const std::string REQ_ALLOW_NO_USER = "AllowNoUser"
 
static const std::string SECURITY_TYPE_NONE = "NoSecurity"
 
static const std::string SECURITY_TYPE_DIGEST_ACCESS = "DigestAccessAuthentication"
 
static const std::string SECURITY_TYPE_DEFAULT = WebUsers::SECURITY_TYPE_NONE
 
static std::atomic< bool > remoteLoginVerificationEnabled_ = false
 true if this supervisor is under control of a remote supervisor
 

Detailed Description

WebUsers This class provides the functionality for managing all otsdaq user account preferences and permissions.

Definition at line 37 of file WebUsers.h.

Member Enumeration Documentation

◆ anonymous enum

anonymous enum
Enumerator
PERMISSION_LEVEL_ADMIN 

max permission level!

Definition at line 62 of file WebUsers.h.

◆ anonymous enum

anonymous enum
Enumerator
SYS_CLEANUP_WILDCARD_TIME 

300 seconds

Definition at line 190 of file WebUsers.h.

Member Function Documentation

◆ addSystemMessage() [1/3]

void WebUsers::addSystemMessage ( const std::string &  targetUsersCSV,
const std::string &  message 
)

addSystemMessage targetUser can be "*" for all users

Definition at line 3495 of file WebUsers.cc.

◆ addSystemMessage() [2/3]

void WebUsers::addSystemMessage ( const std::string &  targetUsersCSV,
const std::string &  subject,
const std::string &  message,
bool  doEmail 
)

addSystemMessage targetUser can be "*" for all users

Definition at line 3504 of file WebUsers.cc.

◆ addSystemMessage() [3/3]

void WebUsers::addSystemMessage ( const std::vector< std::string > &  targetUsers,
const std::string &  subject,
const std::string &  message,
bool  doEmail 
)

addSystemMessage targetUser can be "*" for all users Note: do not printout message, because if it was a Console trigger, it will fire repeatedly

Definition at line 3518 of file WebUsers.cc.

◆ attemptActiveSession()

uint64_t WebUsers::attemptActiveSession ( const std::string &  uuid,
std::string &  jumbledUser,
const std::string &  jumbledPw,
std::string &  newAccountCode,
const std::string &  ip 
)

WebUsers::attemptActiveSession — Attempts login.

If new login, then new account code must match account creation time and account is made with pw

if old login, password is checked returns User Id, cookieCode in newAccountCode, and displayName in jumbledUser on success else returns -1 and cookieCode "0"

Definition at line 1106 of file WebUsers.cc.

◆ attemptActiveSessionWithCert()

uint64_t WebUsers::attemptActiveSessionWithCert ( const std::string &  uuid,
std::string &  email,
std::string &  cookieCode,
std::string &  user,
const std::string &  ip 
)

WebUsers::attemptActiveSessionWithCert — Attempts login using certificate.

returns User Id, cookieCode, and displayName in jumbledEmail on success else returns -1 and cookieCode "0"

Definition at line 1298 of file WebUsers.cc.

◆ checkIpAccess()

bool WebUsers::checkIpAccess ( const std::string &  ip)

WebUsers::checkIpAccess — checks user defined accept cache, then checks reject IP cache then checks blacklist cache return true if ip is accepted, and false if rejected

Definition at line 1950 of file WebUsers.cc.

◆ checkRequestAccess()

bool WebUsers::checkRequestAccess ( cgicc::Cgicc &  cgi,
std::ostringstream *  out,
HttpXmlDocument xmldoc,
WebUsers::RequestUserInfo userInfo,
bool  isWizardMode = false,
const std::string &  wizardModeSequence = "" 
)
static

checkRequestAccess – static function Check user permission parameters based on cookie code, user permission level (extracted previous from group membership) Note: assumes userInfo.groupPermissionLevelMap_ and userInfo.permissionLevel_ are properly setup by either calling userInfo.setGroupPermissionLevels() or userInfo.getGroupPermissionLevel()

Definition at line 255 of file WebUsers.cc.

◆ cleanupExpiredEntries()

void WebUsers::cleanupExpiredEntries ( std::vector< std::string > *  loggedOutUsernames = 0)

WebUsers::cleanupExpiredEntries — cleanup expired entries from Login Session and Active Session databases check if usersUsernameWithLock_ is still active return the vector of logged out user names if a parameter if not a parameter, store logged out user names for next time called with parameter

Definition at line 2308 of file WebUsers.cc.

◆ cleanupExpiredRemoteEntries()

void WebUsers::cleanupExpiredRemoteEntries ( void  )

WebUsers::cleanupExpiredRemoteEntries — cleanup expired entries from Remote Active Session databases Give less time than ACTIVE_SESSION_EXPIRATION_TIME (e.g. /4, and assume safe to keep session open and cached locally to avoid hitting remote server with back-to-back requests)

Definition at line 2406 of file WebUsers.cc.

◆ cookieCodeIsActiveForRequest()

bool WebUsers::cookieCodeIsActiveForRequest ( std::string &  cookieCode,
std::map< std::string, WebUsers::permissionLevel_t > *  userPermissions = 0,
uint64_t *  uid = 0,
const std::string &  ip = "0",
bool  refresh = true,
bool  doNotGoRemote = false,
std::string *  userWithLock = 0,
uint64_t *  userSessionIndex = 0 
)

WebUsers::isCookieCodeActiveForRequest — Used to verify cookie code for all general user requests cookieCode/ip must be active to pass

cookieCode is passed by reference. It is refreshed, if refresh=true on success and may be modified. on success, if userPermissions and/or uid are not null, the permissions and uid are returned on failure, cookieCode contains error message to return to client

If do NOT care about cookie code, then returns uid 0 (admin) and grants full permissions

Definition at line 2130 of file WebUsers.cc.

◆ cookieCodeLogout()

uint64_t WebUsers::cookieCodeLogout ( const std::string &  cookieCode,
bool  logoutOtherUserSessions,
uint64_t *  userId = 0,
const std::string &  ip = "0" 
)

WebUsers::cookieCodeLogout — Used to logout user based on cookieCode and ActiveSessionIndex logoutOtherUserSessions true logs out all of user's other sessions by uid Note: when true, user will remain logged in to current active session logoutOtherUserSessions false logs out only this cookieCode/ActiveSessionIndex Note: when false, user will remain logged in other locations based different ActiveSessionIndex

on failure, returns -1 on success returns number of active sessions that were removed

Definition at line 2057 of file WebUsers.cc.

◆ createNewAccount()

void WebUsers::createNewAccount ( const std::string &  username,
const std::string &  displayName,
const std::string &  email 
)

createNewAccount adds a new valid user to database inputs: username and name to display initializes database entry with minimal permissions and salt starts as "" until password is set Special case if first user name!! max permissions given (super user made) //Note: username, userId, AND displayName must be unique!

Definition at line 1003 of file WebUsers.cc.

◆ createNewLoginSession()

std::string WebUsers::createNewLoginSession ( const std::string &  UUID,
const std::string &  ip 
)

createNewLoginSession adds a new login session id to database inputs: UUID checks that UUID is unique initializes database entry and returns sessionId std::string return "" on failure

Definition at line 2429 of file WebUsers.cc.

◆ getActiveSessionCountForUser()

uint64_t WebUsers::getActiveSessionCountForUser ( uint64_t  uid)

WebUsers::getActiveSessionCountForUser — Returns count of unique ActiveSessionIndex entries for user's uid

Definition at line 1915 of file WebUsers.cc.

◆ getActiveUserCount()

size_t WebUsers::getActiveUserCount ( void  )

WebUsers::getActiveUserCount return count of active Display Names

Definition at line 3396 of file WebUsers.cc.

◆ getActiveUsersString()

std::string WebUsers::getActiveUsersString ( void  )

WebUsers::getActiveUsersString return comma separated list of active Display Names

Definition at line 3408 of file WebUsers.cc.

◆ getAdminUserID()

uint64_t WebUsers::getAdminUserID ( void  )

WebUsers::getAdminUserID

Definition at line 3441 of file WebUsers.cc.

◆ getAllSystemMessages()

std::string WebUsers::getAllSystemMessages ( void  )

getAllSystemMessages Returns string all all system messages by user (for remote gateway monitoring) Format: targetUser | time | msg | targetUser | time | msg...etc

Definition at line 3754 of file WebUsers.cc.

◆ getGenericPreference()

std::string WebUsers::getGenericPreference ( uint64_t  uid,
const std::string &  preferenceName,
HttpXmlDocument xmldoc = 0 
) const

WebUsers::getGenericPreference each generic preference has its own directory, and each user has their own file default preference is empty string.

Definition at line 3063 of file WebUsers.cc.

◆ getLastSystemMessage()

std::pair< std::string, time_t > WebUsers::getLastSystemMessage ( void  )

getAllSystemMessages Returns last *‍/global system message for statusing

Definition at line 3733 of file WebUsers.cc.

◆ getPermissionsForUser()

std::map< std::string, WebUsers::permissionLevel_t > WebUsers::getPermissionsForUser ( uint64_t  uid)

from Gateway, use public version which considers remote users

WebUsers::getPermissionForUser return WebUsers::PERMISSION_LEVEL_INACTIVE if invalid index

Definition at line 2568 of file WebUsers.cc.

◆ getSystemMessage()

std::string WebUsers::getSystemMessage ( const std::string &  targetUser)

getSystemMessage Deliver | separated system messages (time | msg | time | msg...etc), if there is any in vector set for user or for wildcard * Empty std::string "" returned if no message for targetUser Note: | is an illegal character and will cause GUI craziness Note: targetUser is by display name

Definition at line 3786 of file WebUsers.cc.

◆ getUsersDisplayName()

std::string WebUsers::getUsersDisplayName ( uint64_t  uid)

from Gateway, use public version which considers remote users

WebUsers::getUsersDisplayName —.

Definition at line 2028 of file WebUsers.cc.

◆ getUsersUsername()

std::string WebUsers::getUsersUsername ( uint64_t  uid)

from Gateway, use public version which considers remote users

WebUsers::getUsersUsername —.

Definition at line 2038 of file WebUsers.cc.

◆ initializeRequestUserInfo()

void WebUsers::initializeRequestUserInfo ( cgicc::Cgicc &  cgi,
WebUsers::RequestUserInfo userInfo 
)
static

used by gateway and other supervisors to verify requests consistently

initializeRequestUserInfo initialize user info parameters to failed results

Definition at line 234 of file WebUsers.cc.

◆ insertSettingsForUser()

void WebUsers::insertSettingsForUser ( uint64_t  uid,
HttpXmlDocument xmldoc,
bool  includeAccounts = false 
)

WebUsers::insertGetSettingsResponse add settings to xml document all active users have permissions of at least 1 so have web preferences: -background color -dashboard color -window color -3 user defaults for window layouts(and current), can set current as one of defaults super users have account controls: -list of user accounts to edit permissions, display name, or delete account -add new account ...and super users have system default window layout -2 system defaults for window layouts

layout settings explanation 0 = no windows, never set, empty desktop example 2 layouts set, 2 not, [<win name>, <win subname>, <win url>, <x>, <y>, <w>, <h>]; [<win name>, <win subname>, <win url>, <x>, <y>, <w>, <h>]...];0;0

Definition at line 2902 of file WebUsers.cc.

◆ isCookieCodeActiveForLogin()

uint64_t WebUsers::isCookieCodeActiveForLogin ( const std::string &  uuid,
std::string &  cookieCode,
std::string &  username 
)

WebUsers::IsCookieActive — returns User Id on success, returns by reference refreshed cookieCode and displayName if cookieCode/user combo is still active displayName is returned in username std::string else returns -1

Definition at line 1858 of file WebUsers.cc.

◆ isUserIdActive()

bool WebUsers::isUserIdActive ( uint64_t  uid) const

WebUsers::isUserIdActive — returns true if found, else false

Definition at line 1625 of file WebUsers.cc.

◆ isUsernameActive()

bool WebUsers::isUsernameActive ( const std::string &  username) const

WebUsers::isUsernameActive — returns true if found, else false

Definition at line 1614 of file WebUsers.cc.

◆ loadActiveSessions()

void WebUsers::loadActiveSessions ( void  )

loadActiveSessions load active sessions structure so that they can survive restart

Definition at line 442 of file WebUsers.cc.

◆ saveActiveSessions()

void WebUsers::saveActiveSessions ( void  )

saveActiveSessions save active sessions structure so that they can survive restart

Definition at line 402 of file WebUsers.cc.

◆ setGenericPreference()

void WebUsers::setGenericPreference ( uint64_t  uid,
const std::string &  preferenceName,
const std::string &  preferenceValue 
)

WebUsers::setGenericPreference each generic preference has its own directory, and each user has their own file

Definition at line 3022 of file WebUsers.cc.

◆ setUserWithLock()

bool WebUsers::setUserWithLock ( uint64_t  actingUid,
bool  lock,
const std::string &  username 
)

WebUsers::setUserWithLock if lock is true, set lock user specified if lock is false, attempt to unlock user specified return true on success

Definition at line 3168 of file WebUsers.cc.

◆ silenceAllUserTooltips()

void WebUsers::silenceAllUserTooltips ( const std::string &  username)
static

WebUsers::silenceAllUserTooltips creates a file

Definition at line 2867 of file WebUsers.cc.

◆ tooltipCheckForUsername()

void WebUsers::tooltipCheckForUsername ( const std::string &  username,
HttpXmlDocument xmldoc,
const std::string &  srcFile,
const std::string &  srcFunc,
const std::string &  srcId 
)
static

WebUsers::tooltipCheckForUsername read file for tooltip if not 1 then never show if 0 then "always show" if other then treat as temporary mute.. i.e. if time(0) > val show

Definition at line 2791 of file WebUsers.cc.

◆ tooltipSetNeverShowForUsername()

void WebUsers::tooltipSetNeverShowForUsername ( const std::string &  username,
HttpXmlDocument xmldoc,
const std::string &  srcFile,
const std::string &  srcFunc,
const std::string &  srcId,
bool  doNeverShow,
bool  temporarySilence 
)
static

WebUsers::tooltipSetNeverShowForUsername temporarySilence has priority over the neverShow setting

Definition at line 2733 of file WebUsers.cc.

◆ xmlRequestOnGateway()

bool WebUsers::xmlRequestOnGateway ( cgicc::Cgicc &  cgi,
std::ostringstream *  out,
HttpXmlDocument xmldoc,
WebUsers::RequestUserInfo userInfo 
)

for the gateway supervisor to check request access if false, gateway request handling code should just return.. out is handled on false; on true, out is untouched

xmlRequestOnGateway check the validity of an xml request at the server side, i.e. at the Gateway supervisor, which is the owner of the web users instance. if false, gateway request code should just return.. out is handled on false; on true, out is untouched

Definition at line 175 of file WebUsers.cc.


The documentation for this class was generated from the following files: