diff options
author | Howaner <franzi.moos@googlemail.com> | 2014-02-21 14:53:46 +0100 |
---|---|---|
committer | Howaner <franzi.moos@googlemail.com> | 2014-02-21 14:53:46 +0100 |
commit | 21febaf4b342aecd5d797b1e2017591fde208388 (patch) | |
tree | beaf6b0b623a08052932351f64fb9d0924dd6d4d /src/GroupManager.cpp | |
parent | Bad UTF-8 o.O (diff) | |
download | cuberite-21febaf4b342aecd5d797b1e2017591fde208388.tar cuberite-21febaf4b342aecd5d797b1e2017591fde208388.tar.gz cuberite-21febaf4b342aecd5d797b1e2017591fde208388.tar.bz2 cuberite-21febaf4b342aecd5d797b1e2017591fde208388.tar.lz cuberite-21febaf4b342aecd5d797b1e2017591fde208388.tar.xz cuberite-21febaf4b342aecd5d797b1e2017591fde208388.tar.zst cuberite-21febaf4b342aecd5d797b1e2017591fde208388.zip |
Diffstat (limited to '')
-rw-r--r-- | src/GroupManager.cpp | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/src/GroupManager.cpp b/src/GroupManager.cpp index 723b86f94..5125e7586 100644 --- a/src/GroupManager.cpp +++ b/src/GroupManager.cpp @@ -46,6 +46,7 @@ cGroupManager::cGroupManager() LOGD("-- Loading Groups --"); LoadGroups(); + CheckUsers(); LOGD("-- Groups Successfully Loaded --"); } @@ -54,6 +55,42 @@ cGroupManager::cGroupManager() +void cGroupManager::CheckUsers(void) +{ + cIniFile IniFile; + if (!IniFile.ReadFile("users.ini")) + { + LOGWARN("Regenerating users.ini, all users will be reset"); + IniFile.AddHeaderComment(" This is the file in which the group the player belongs to is stored"); + IniFile.AddHeaderComment(" The format is: [PlayerName] | Groups=GroupName"); + + IniFile.WriteFile("users.ini"); + return; + } + + unsigned int NumKeys = IniFile.GetNumKeys(); + for (size_t i = 0; i < NumKeys; i++) + { + AString Player = IniFile.GetKeyName( i ); + AString Groups = IniFile.GetValue(Player, "Groups", ""); + if (!Groups.empty()) + { + AStringVector Split = StringSplit( Groups, "," ); + for( unsigned int i = 0; i < Split.size(); i++ ) + { + if (!ExistsGroup(Split[i])) + { + LOGWARNING("The group %s for player %s was not found!", Split[i].c_str(), Player.c_str()); + } + } + } + } +} + + + + + void cGroupManager::LoadGroups() { cIniFile IniFile; @@ -137,6 +174,16 @@ void cGroupManager::LoadGroups() +bool cGroupManager::ExistsGroup( const AString & a_Name ) +{ + GroupMap::iterator itr = m_pState->Groups.find( a_Name ); + return ( itr != m_pState->Groups.end() ); +} + + + + + cGroup* cGroupManager::GetGroup( const AString & a_Name ) { GroupMap::iterator itr = m_pState->Groups.find( a_Name ); |