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.