The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package Schema::Abilities::Result::User;

# Created by DBIx::Class::Schema::Loader
# DO NOT MODIFY THE FIRST PART OF THIS FILE

use strict;
use warnings;

use Moose;
use MooseX::NonMoose;
use namespace::autoclean;
extends 'DBIx::Class::Core';

__PACKAGE__->load_components(
  "InflateColumn::DateTime",
  "DateTime::Epoch",
  "TimeStamp",
  "EncodedColumn",
);

=head1 NAME

Schema::Abilities::Result::User

=cut

__PACKAGE__->table("users");

=head1 ACCESSORS

=head2 id

  data_type: 'integer'
  is_auto_increment: 1
  is_nullable: 0

=head2 username

  data_type: 'varchar'
  is_nullable: 0
  size: 40

=head2 name

  data_type: 'varchar'
  is_nullable: 0
  size: 40

=head2 password

  data_type: 'char'
  is_nullable: 0
  size: 40

=head2 email

  data_type: 'varchar'
  is_nullable: 0
  size: 100

=head2 created

  data_type: 'timestamp'
  datetime_undef_if_invalid: 1
  default_value: current_timestamp
  is_nullable: 0

=head2 active

  data_type: 'tinyint'
  default_value: 0
  is_nullable: 0

=cut

__PACKAGE__->add_columns(
  "id",
  { data_type => "integer", is_auto_increment => 1, is_nullable => 0 },
  "username",
  { data_type => "varchar", is_nullable => 0, size => 40 },
  "name",
  { data_type => "varchar", is_nullable => 0, size => 40 },
  "password",
  { data_type => "char", is_nullable => 0, size => 40 },
  "email",
  { data_type => "varchar", is_nullable => 0, size => 100 },
  "created",
  {
    data_type => "timestamp",
    datetime_undef_if_invalid => 1,
    default_value => \"current_timestamp",
    is_nullable => 0,
  },
  "active",
  { data_type => "tinyint", default_value => 0, is_nullable => 0 },
);
__PACKAGE__->set_primary_key("id");
__PACKAGE__->add_unique_constraint("username_unique", ["username"]);

=head1 RELATIONS

=head2 user_roles

Type: has_many

Related object: L<Schema::Abilities::Result::UserRole>

=cut

__PACKAGE__->has_many(
  "user_roles",
  "Schema::Abilities::Result::UserRole",
  { "foreign.user_id" => "self.id" },
  { cascade_copy => 0, cascade_delete => 0 },
);


# Created by DBIx::Class::Schema::Loader v0.07010 @ 2011-10-17 10:52:30
# DO NOT MODIFY THIS OR ANYTHING ABOVE! md5sum:LfU+tTgwQl5x69IjYSck0g


__PACKAGE__->add_columns(
                         "password" => {
                                        data_type           => "CHAR",
                                        is_nullable         => 0,
                                        size                => 40,
                                        encode_column       => 1,
                                        encode_class        => 'Digest',
                                        encode_args         => { algorithm => 'SHA-1', format => 'hex' },
                                        encode_check_method => 'check_password',
                                       },
                         "created",
                         {
                          data_type     => "timestamp",
                          is_nullable   => 0,
                          inflate_datetime => 'epoch',
                          set_on_create    => 1,
                         },
                        );

__PACKAGE__->has_many(map_user_role => 'Schema::Abilities::Result::UserRole', 'user_id',
                      { cascade_copy => 0, cascade_delete => 0 });

__PACKAGE__->many_to_many(user_roles => 'map_user_role', 'role');

__PACKAGE__->has_many(map_user_action => 'Schema::Abilities::Result::UserAction', 'user_id',
                      { cascade_copy => 0, cascade_delete => 0 });

__PACKAGE__->many_to_many(actions => 'map_user_action', 'action');


__PACKAGE__->meta->make_immutable;
1;