Class-User-DBI
view release on metacpan or search on metacpan
lib/Class/User/DBI/UserDomains.pm view on Meta::CPAN
It will drop requests to add domains that already exist for a given user.
Returns a count of domains added, which may be less than the number passed if
one already existed.
=head2 delete_domains
$ud->delete_domains( 'California', 'Florida' ); # No more sunny beaches.
Deletes from the user all domains specified. Return value is the number
of domains actually deleted, which may be less than the number of domains
requested if any of the requested domains don't exist for the object's target
user.
=head2 has_domain
print "This user gets to enjoy the surf."
if $ud->has_domain( 'Hawaii' );
Returns true if a given domain exists for the object's target user, and
false if not.
=head2 fetch_domains
foreach my $domain ( $ud->fetch_domains ) {
print "This user works with $domain\n";
}
Returns a list of domains belonging to the object's target user.
An empty list means there are no domains defined for this user.
=head2 get_userid
my $userid = $ud->get_userid;
Just an accessor for reading the object's target user ID.
=head1 DEPENDENCIES
The dependencies for this module are the same as for L<Class::User::DBI>, from
this same distribution. Refer to the documentation in that module for a full
description.
=head1 CONFIGURATION AND ENVIRONMENT
Please refer to the C<configure_db()> class method for this module for a
simple means of creating the table that supports this class.
All SQL for this distribution is contained in the L<Class::User::DBI::DB>
module.
=head1 DIAGNOSTICS
If you find that your particular database engine is not playing nicely with the
test suite from this module, it may be necessary to provide the database login
credentials for a test database using the same engine that your application
will actually be using. You may do this by setting C<$ENV{CUDBI_TEST_DSN}>,
C<$ENV{CUDBI_TEST_DATABASE}>, C<$ENV{CUDBI_TEST_USER}>,
and C<$ENV{CUDBI_TEST_PASS}>.
Currently the test suite tests against a SQLite database since it's such a
lightweight dependency for the testing. The author also uses this module
with several MySQL databases. As you're configuring your database, providing
its credentials to the tests and running the test scripts will offer really
good diagnostics if some aspect of your database tables proves to be at odds
with what this module needs.
=head1 INCOMPATIBILITIES
This module has only been tested on MySQL and SQLite database engines. If you
are successful in using it with other engines, please send me an email detailing
any additional configuration changes you had to make so that I can document
the compatibility, and improve the documentation for the configuration process.
=head1 BUGS AND LIMITATIONS
Let me know if you find any!
=head1 AUTHOR
David Oswald, C<< <davido at cpan.org> >>
=head1 BUGS
Please report any bugs or feature requests to
C<bug-class-user-dbi at rt.cpan.org>, or through the web interface at
L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Class-User-DBI>. I will be
notified, and then you'll automatically be notified of progress on your bug as
I make changes.
=head1 SUPPORT
You can find documentation for this module with the perldoc command.
perldoc Class::User::DBI::UserDomains
You can also look for information at:
=over 4
=item * Class-User-DBI on Github
L<https://github.com/daoswald/Class-User-DBI.git>
=item * RT: CPAN's request tracker (report bugs here)
L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=Class-User-DBI>
=item * AnnoCPAN: Annotated CPAN documentation
L<http://annocpan.org/dist/Class-User-DBI>
=item * CPAN Ratings
L<http://cpanratings.perl.org/d/Class-User-DBI>
=item * Search CPAN
( run in 1.177 second using v1.01-cache-2.11-cpan-39bf76dae61 )