NAME
A class for TABLE users in schema main
SYNOPSIS
#In a controller use the helper.
#Find a user by login_name and change the current user
my $user = Ado::Model::Users->by_login_name($login_name);
$c->user($user);
#in a template
<h1>Hello, <%=user->name%>!</h1>
#Add a new user.
my $user = Ado::Model::Users->adduser(login_name=>'petko'...);
#Add the user to a group
$user->add_to_group('cool');
DESCRIPTION
This class maps to rows in table users
.
ATTRIBUTES
Ado::Model::Users inherits all attributes from Ado::Model and provides the following.
name
Readonly. Returns concatenated "first_name" and "last_name" of the user or the username (in case the first two are not available).
# Hello, Guest
<h1>Hello, <%=user->name%>!</h1>
COLUMNS
Each column from table users
has an accessor method in this class.
id
group_id
login_name
login_password
first_name
last_name
description
created_by
changed_by
tstamp
reg_date
disabled
start_date
stop_date
ALIASES
none
METHODS
Ado::Model::Users inherits all methods from Ado::Model and provides the following additional methods:
adduser
Given enough parameters creates a new user object and inserts it into the table users
. Creates a primary group for the user with the same group name
. Throws an exception if any of the above fails. Returns (the eventually newly created) user object.
my $user = Ado::Model::Users->adduser(
login_name => $login_name,
login_password => Mojo::Util::sha1_hex($login_name.$login_password)
);
add_to_group
Adds a user with login_name
to a group. Creates the group if it does not already exists. Returns the group.
$ingroup = Ado::Model::Users->add_to_group(login_name=>'petko',ingroup=>'admin');
by_login_name
Selects a user by login_name column.
my $user = Ado::Model::Users->by_login_name('guest');
say $user->login_name if $user->id;
ingroup
Given a group name returns true if a user is member of the group. Returns false otherwise. Returns a list of all group names a user belongs to if no group name passed.
say $user->name . ' is admin!' if $user->ingroup('admin');
say $user->name .' is member of the following groups:'
. join(', ', $user->ingroup);
GENERATOR
This class contains also custom code.
SEE ALSO
Ado::Command::adduser, Ado::Model, DBIx::Simple::Class, DBIx::Simple::Class::Schema