NAME
Unix::Mgt - lightweight Unix management tools
SYNOPSIS
# get user account
$user = Unix::Mgt::User->get('fred');
# display some info
print 'uid: ', $user->uid, "\n";
print join(', ', $user->groups()), "\n";
# set some properties
$user->gid('websters');
$user->shell('/bin/bash');
$user->add_to_group('postgres');
# create user account
$user = Unix::Mgt::User->create('vera');
# get user account, creating it if necessary
$user = Unix::Mgt::User->ensure('molly');
# get group
$group = Unix::Mgt::Group->get('www-data');
# display some info
print 'gid: ', $group->gid, "\n";
print join(', ', $group->members()), "\n";
# add a member
$group->add_member('tucker');
DESCRIPTION
Unix::Mgt provides simple object-oriented tools for managing your
Unixish system. Currently this module provides tools for managing users
and groups. Other tools may follow as they evolve.
Unix::Mgt does not directly manipulate any of the system files such as
/etc/passwd. This module uses Perl's built-in Unix functions such as
getgrent to get information, and Unix's built-in programs such as
adduser.
Early release
In the spirit of "release early, release often", I'm releasing this
version of Unix::Mgt before it has all the features that might be
expected. This version does not include methods for removing users from
groups, renaming users or groups, or several other methods.
Help with BSD development
This version does not work well on BSDish systems. Although the methods
for retrieving information such as get and group work well, this module
currently cannot create, modify, or delete users or group. If you'd
like to help fill in these features, here's what needs to be done.
Several places in the code is the comment "BSD code needed". In those
places what we need is to build an array consisting of an external
command and the arguments to be sent to the command. It would look
something like this:
# build command
@cmd = (
'pw',
'useradd',
$user->{'name'},
'-G',
$group->{'name'},
);
The first element of the array is the program to be run. You don't need
to put the full path of the program, Unix::SearchPathGuess should find
it. (If it doesn't please let me know, we may need to fix
Unix::SearchPathGuess.) The remaining elements are the params sent to
the program using IPC::System::Simple. The program is not run in a
shell, but instead is called directly, so it isn't necessary to do any
shell escaping.
The following methods currently need patching. In Unix::Mgt::User we
need create(), field_get_set(), group(), add_to_group(), and remove().
In Unix::Mgt::Group we need create() and remove(). We will need more as
we add features to this module.
Please email me at miko@idocs.com if you've made these mods.
Unix::Mgt::User
A Unix::Mgt::User object represents a user in the Unix system. The
object allows you to get and set information about the user account. A
user object is created in one of three ways: get, create, or ensure.
Note that there is no new method.
Unix::Mgt::User objects stringify to the account's name. For example,
the following code would output miko.
$user = Unix::Mgt::User->get('miko');
print $user, "\n";
get
Unix::Mgt::User->get() retrieves user account information using
getpwnam or getpwuid. The single param for this method is either the
name or the uid of the user.
$user = Unix::Mgt::User->get('vera');
$user = Unix::Mgt::User->get('1010');
If the user is not found then the do-not-have-user error id is set in
$Unix::Mgt::err_id and undef is returned.
create
Unix::Mgt::User->create() creates a user account. The required param
for this method is the name for the new account.
$user = Unix::Mgt::User->create('vera');
If the system param is true, then the account is created as a system
user, like this:
$user = Unix::Mgt::User->create('lanny', system=>1);
create() uses the Unix adduser program.
ensure
Unix::Mgt::User->ensure() gets a user account if it already exists, and
creates the account if it does not. For example, the following lines
ensures the molly account:
$user = Unix::Mgt::User->ensure('molly');
name
Returns the name of the user account. Currently this method cannot be
used to set the account name.
print $user->name(), "\n";
uid
Returns the user's user id (uid).
print $user->uid(), "\n";
passwd
Returns the password field from getpwname(). This method will not
actually return a password, it will probably just return *.
print $user->passwd(), "\n"; # probably outputs "*"
gid
Sets/gets the gid of the user's primary group. Called without params,
it returns the user's gid:
print $user->gid(), "\n";
Called with a single param, gid() sets, then returns the user's primary
group id:
print $user->gid('1010'), "\n";
If you want to get a Unix::Mgt::Group object representing the user's
primary group, use $user->group().
dir
Sets/gets the user's home directory. Called without params, it returns
the directory name:
print $user->dir(), "\n";
Called with a single param, dir() sets, then returns the user's home
directory:
print $user->dir('/tmp'), "\n";
shell
Sets/gets the user's default command line shell. Called without params,
it returns the shell name:
print $user->shell(), "\n";
Called with a single param, shell() sets, then returns the user's
shell:
print $user->shell('/bin/sh'), "\n";
group
Sets/gets the user's primary group. When called without any params,
group() returns a Unix::Mgt::Group object representing the user's
primary group:
$group = $user->group();
When called with a single param, group() sets the user's primary group.
The param can be either the group's name or its gid:
$user->group('video');
$user->group(44);
secondary_groups
secondary_groups() returns an array of the user's secondary groups.
Each element in the array is a Unix::Mgt::Group object.
@groups = $user->secondary_groups();
groups
groups() returns an array of all of the groups the user is a member of.
The first element in the array will be the user's primary group.
@groups = $user->groups();
add_to_group
add_to_group() adds the user to a group. The group will be one of the
user's secondary groups, not the primary group.
$user->add_to_group('video');
remove
remove removes the user account from the system. remove does not take
any parameters.
$user->remove();
Unix::Mgt::Group
A Unix::Mgt::Group object represents a group in the Unix system. The
object allows you to get and set information about the group. A group
object is created in one of three ways: get, create, or ensure. Note
that there is no new method.
Unix::Mgt::Group objects stringify to the groups's name. For example,
the following code would output video.
$group = Unix::Mgt::Group->get('video');
print $group, "\n";
get
Unix::Mgt::Group->get() retrieves group information using getgrnam or
getgrgid. The single param for this method is either the name or the
gid of the group.
$group = Unix::Mgt::Group->get('video');
$group = Unix::Mgt::Group->get('44');
If the group is not found then the do-not-have-group error id is set in
$Unix::Mgt::err_id and undef is returned.
create
Unix::Mgt::Group->create() creates a group. The required param for this
method is the name for the new group.
$group = Unix::Mgt::Group->create('websters');
create() uses the Unix groupadd program.
ensure
Unix::Mgt::Group->ensure() gets a group if it already exists, and
creates the group if it does not. For example, the following lines
ensures the wbesters group:
$group = Unix::Mgt::User->ensure('wbesters');
name
Returns the name of the group. Currently this method cannot be used to
set the group name.
print $group->name(), "\n";
gid
Returns the groups's group id (gid).
print $group->gid(), "\n";
members
members() returns an array of all members of the group. Both users for
whom this is the primary group, and users for whom this is a secondary
group are returned.
@members = $group->members();
The elements in the array are Unix::Mgt::User objects.
primary_members
primary_members() returns an array of users for whom this is the
primary group.
@members = $group->primary_members();
The elements in the returned array are Unix::Mgt::User objects.
secondary_members
secondary_members() returns an array of users for whom this is a
secondary group.
@members = $group->secondary_members();
The elements in the returned array are Unix::Mgt::User objects.
add_member
add_member() adds a user to the group as a secondary group. The single
param can be a user name, uid, or Unix::Mgt::User object.
$group->add_member('miko');
If the user is already a member of the group then nothing is done and
no error is set.
remove
remove removes the group from the system. remove does not take any
parameters.
$group->remove();
If any users have the group as a primary group then this method will
fail.
SEE ALSO
Passwd::Unix and
Unix::Passwd::File
provide similar
functionality.
TERMS AND CONDITIONS
Copyright (c) 2014 by Miko O'Sullivan. All rights reserved. This
program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself. This software comes with no
warranty of any kind.
AUTHOR
Miko O'Sullivan miko@idocs.com
TO DO
This is an early release of Unix::Mgt. It does not include methods for
deleting users, removing them from groups, or other deletion oriented
objectives.
Please feel free to contribute code for these purposes.
HISTORY
Version 0.10 December 30, 2014
Initial release
Version 0.11 December 31, 2014
Changed addgroup to groupadd.
Added tests for existence of adduser, usermod, and groupadd.
Version 0.12 January 3, 2015
Fixed some POD formatting issues.
Revised tests to include test names.
Version 0.13 January 4, 2015
Added $user->remove() and $group->remove().
Added slots where BSD-style commands will go. Currently, methods for
creating, modifying, or deleting users or group will fail on BSD.