diff options
author | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2011-11-06 15:56:40 -0600 |
---|---|---|
committer | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2011-11-06 15:56:40 -0600 |
commit | e16866e072f94410321d70daedbcb855ea878cac (patch) | |
tree | ee3f52eabde7da1a0e6ca845fb9c2813cf1558cf /tdecore/kuser.cpp | |
parent | a58c20c1a7593631a1b50213c805507ebc16adaf (diff) | |
download | tdelibs-e16866e072f94410321d70daedbcb855ea878cac.tar.gz tdelibs-e16866e072f94410321d70daedbcb855ea878cac.zip |
Actually move the kde files that were renamed in the last commit
Diffstat (limited to 'tdecore/kuser.cpp')
-rw-r--r-- | tdecore/kuser.cpp | 425 |
1 files changed, 425 insertions, 0 deletions
diff --git a/tdecore/kuser.cpp b/tdecore/kuser.cpp new file mode 100644 index 000000000..3fffddf4f --- /dev/null +++ b/tdecore/kuser.cpp @@ -0,0 +1,425 @@ +/* + * KUser - represent a user/account + * Copyright (C) 2002 Tim Jansen <tim@tjansen.de> + * + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library 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 + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public License + * along with this library; see the file COPYING.LIB. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + */ + +#include <kuser.h> + +#include "kstringhandler.h" +#include <tqvaluelist.h> +#include <tqstringlist.h> + +#include <sys/types.h> +#include <pwd.h> +#include <unistd.h> +#include <stdlib.h> +#include <grp.h> + + +class KUserPrivate : public KShared +{ +public: + bool valid; + long uid, gid; + TQString loginName, fullName; + TQString roomNumber, workPhone, homePhone; + TQString homeDir, shell; + + KUserPrivate() : valid(false) {} + + KUserPrivate(long _uid, + long _gid, + const TQString &_loginname, + const TQString &_fullname, + const TQString &_room, + const TQString &_workPhone, + const TQString &_homePhone, + const TQString &_homedir, + const TQString &_shell) : + valid(true), + uid(_uid), + gid(_gid), + loginName(_loginname), + fullName(_fullname), + roomNumber(_room), + workPhone(_workPhone), + homePhone(_homePhone), + homeDir(_homedir), + shell(_shell) {} +}; + + +KUser::KUser(UIDMode mode) { + long _uid = ::getuid(), _euid; + if (mode == UseEffectiveUID && (_euid = ::geteuid()) != _uid ) + fillPasswd( ::getpwuid( _euid ) ); + else { + fillName( ::getenv( "LOGNAME" ) ); + if (uid() != _uid) { + fillName( ::getenv( "USER" ) ); + if (uid() != _uid) + fillPasswd( ::getpwuid( _uid ) ); + } + } +} + +KUser::KUser(long uid) { + fillPasswd( ::getpwuid( uid ) ); +} + +KUser::KUser(const TQString& name) { + fillName( name.local8Bit().data() ); +} + +KUser::KUser(const char *name) { + fillName( name ); +} + +KUser::KUser(struct passwd *p) { + fillPasswd(p); +} + +KUser::KUser(const KUser & user) + : d(user.d) +{ +} + +KUser& KUser::operator =(const KUser& user) +{ + d = user.d; + return *this; +} + +bool KUser::operator ==(const KUser& user) const { + if (isValid() != user.isValid()) + return false; + if (isValid()) + return uid() == user.uid(); + else + return true; +} + +bool KUser::operator !=(const KUser& user) const { + return !operator ==(user); +} + +void KUser::fillName(const char *name) { + fillPasswd(name ? ::getpwnam( name ) : 0); +} + +void KUser::fillPasswd(struct passwd *p) { + if (p) { + TQString gecos = KStringHandler::from8Bit(p->pw_gecos); + TQStringList gecosList = TQStringList::split(',', gecos, true); + + d = new KUserPrivate(p->pw_uid, + p->pw_gid, + TQString::fromLocal8Bit(p->pw_name), + (gecosList.size() > 0) ? gecosList[0] : TQString::null, + (gecosList.size() > 1) ? gecosList[1] : TQString::null, + (gecosList.size() > 2) ? gecosList[2] : TQString::null, + (gecosList.size() > 3) ? gecosList[3] : TQString::null, + TQString::fromLocal8Bit(p->pw_dir), + TQString::fromLocal8Bit(p->pw_shell)); + } + else + d = new KUserPrivate(); +} + +bool KUser::isValid() const { + return d->valid; +} + +long KUser::uid() const { + if (d->valid) + return d->uid; + else + return -1; +} + +long KUser::gid() const { + if (d->valid) + return d->gid; + else + return -1; +} + +bool KUser::isSuperUser() const { + return uid() == 0; +} + +TQString KUser::loginName() const { + if (d->valid) + return d->loginName; + else + return TQString::null; +} + +TQString KUser::fullName() const { + if (d->valid) + return d->fullName; + else + return TQString::null; +} + +TQString KUser::roomNumber() const { + if (d->valid) + return d->roomNumber; + else + return TQString::null; +} + +TQString KUser::workPhone() const { + if (d->valid) + return d->workPhone; + else + return TQString::null; +} + +TQString KUser::homePhone() const { + if (d->valid) + return d->homePhone; + else + return TQString::null; +} + +TQString KUser::homeDir() const { + if (d->valid) + return d->homeDir; + else + return TQString::null; +} + +TQString KUser::shell() const { + if (d->valid) + return d->shell; + else + return TQString::null; +} + +TQValueList<KUserGroup> KUser::groups() const { + TQValueList<KUserGroup> result; + TQValueList<KUserGroup> allGroups = KUserGroup::allGroups(); + TQValueList<KUserGroup>::const_iterator it; + for ( it = allGroups.begin(); it != allGroups.end(); ++it ) { + TQValueList<KUser> users = (*it).users(); + if ( users.find( *this ) != users.end()) { + result.append(*it); + } + } + return result; +} + +TQStringList KUser::groupNames() const { + TQStringList result; + TQValueList<KUserGroup> allGroups = KUserGroup::allGroups(); + TQValueList<KUserGroup>::const_iterator it; + for ( it = allGroups.begin(); it != allGroups.end(); ++it ) { + TQValueList<KUser> users = (*it).users(); + if ( users.find( *this ) != users.end()) { + result.append((*it).name()); + } + } + return result; +} + + +TQValueList<KUser> KUser::allUsers() { + TQValueList<KUser> result; + + struct passwd* p; + + while ((p = getpwent())) { + result.append(KUser(p)); + } + + endpwent(); + + return result; +} + +TQStringList KUser::allUserNames() { + TQStringList result; + + struct passwd* p; + + while ((p = getpwent())) { + result.append(TQString::fromLocal8Bit(p->pw_name)); + } + + endpwent(); + return result; +} + + +KUser::~KUser() { +} + +class KUserGroupPrivate : public KShared +{ +public: + bool valid; + long gid; + TQString name; + TQValueList<KUser> users; + + KUserGroupPrivate() : valid(false) {} + + KUserGroupPrivate(long _gid, + const TQString & _name, + const TQValueList<KUser> & _users): + valid(true), + gid(_gid), + name(_name), + users(_users) {} +}; + +KUserGroup::KUserGroup(KUser::UIDMode mode) { + KUser user(mode); + fillGroup(getgrgid(user.gid())); +} + +KUserGroup::KUserGroup(long gid) { + fillGroup(getgrgid(gid)); +} + +KUserGroup::KUserGroup(const TQString& name) { + fillName(name.local8Bit().data()); +} + +KUserGroup::KUserGroup(const char *name) { + fillName(name); +} + +KUserGroup::KUserGroup(struct group *g) { + fillGroup(g); +} + + +KUserGroup::KUserGroup(const KUserGroup & group) + : d(group.d) +{ +} + +KUserGroup& KUserGroup::operator =(const KUserGroup& group) { + d = group.d; + return *this; +} + +bool KUserGroup::operator ==(const KUserGroup& group) const { + if (isValid() != group.isValid()) + return false; + if (isValid()) + return gid() == group.gid(); + else + return true; +} + +bool KUserGroup::operator !=(const KUserGroup& user) const { + return !operator ==(user); +} + +void KUserGroup::fillName(const char *name) { + fillGroup(name ? ::getgrnam( name ) : 0); +} + +void KUserGroup::fillGroup(struct group *p) { + if (!p) { + d = new KUserGroupPrivate(); + return; + } + + TQString name = KStringHandler::from8Bit(p->gr_name); + TQValueList<KUser> users; + + char **user = p->gr_mem; + for ( ; *user; user++) { + KUser kUser(TQString::fromLocal8Bit(*user)); + users.append(kUser); + } + + d = new KUserGroupPrivate(p->gr_gid, + TQString::fromLocal8Bit(p->gr_name), + users); + +} + +bool KUserGroup::isValid() const { + return d->valid; +} + +long KUserGroup::gid() const { + if (d->valid) + return d->gid; + else + return -1; +} + +TQString KUserGroup::name() const { + if (d->valid) + return d->name; + else + return TQString::null; +} + +const TQValueList<KUser>& KUserGroup::users() const { + return d->users; +} + +TQStringList KUserGroup::userNames() const { + TQStringList result; + TQValueList<KUser>::const_iterator it; + for ( it = d->users.begin(); it != d->users.end(); ++it ) { + result.append((*it).loginName()); + } + return result; +} + + + +TQValueList<KUserGroup> KUserGroup::allGroups() { + TQValueList<KUserGroup> result; + + struct group* g; + while ((g = getgrent())) { + result.append(KUserGroup(g)); + } + + endgrent(); + + return result; +} + +TQStringList KUserGroup::allGroupNames() { + TQStringList result; + + struct group* g; + while ((g = getgrent())) { + result.append(TQString::fromLocal8Bit(g->gr_name)); + } + + endgrent(); + + return result; +} + + +KUserGroup::~KUserGroup() { +} + |