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

# 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::Role

=cut

__PACKAGE__->table("roles");

=head1 ACCESSORS

=head2 id

  data_type: 'integer'
  is_auto_increment: 1
  is_nullable: 0

=head2 name

  data_type: 'varchar'
  is_nullable: 0
  size: 100

=head2 active

  data_type: 'tinyint'
  default_value: 1
  is_nullable: 0

=cut

__PACKAGE__->add_columns(
  "id",
  { data_type => "integer", is_auto_increment => 1, is_nullable => 0 },
  "name",
  { data_type => "varchar", is_nullable => 0, size => 100 },
  "active",
  { data_type => "tinyint", default_value => 1, is_nullable => 0 },
);
__PACKAGE__->set_primary_key("id");
__PACKAGE__->add_unique_constraint("name_unique", ["name"]);

=head1 RELATIONS

=head2 role_actions

Type: has_many

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

=cut

__PACKAGE__->has_many(
  "role_actions",
  "Schema::Abilities::Result::RoleAction",
  { "foreign.role_id" => "self.id" },
  { cascade_copy => 0, cascade_delete => 0 },
);

=head2 role_roles_roles

Type: has_many

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

=cut

__PACKAGE__->has_many(
  "role_roles_roles",
  "Schema::Abilities::Result::RoleRole",
  { "foreign.role_id" => "self.id" },
  { cascade_copy => 0, cascade_delete => 0 },
);

=head2 role_roles_inherits_from

Type: has_many

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

=cut

__PACKAGE__->has_many(
  "role_roles_inherits_from",
  "Schema::Abilities::Result::RoleRole",
  { "foreign.inherits_from_id" => "self.id" },
  { cascade_copy => 0, cascade_delete => 0 },
);

=head2 user_roles

Type: has_many

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

=cut

__PACKAGE__->has_many(
  "user_roles",
  "Schema::Abilities::Result::UserRole",
  { "foreign.role_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:6IiGe0MyFjNYsFCkPvnZew


__PACKAGE__->has_many(map_role_actions => 'Schema::Abilities::Result::RoleAction', 'role_id',
                      { cascade_copy => 0, cascade_delete => 0 });


__PACKAGE__->has_many(map_role_roles => 'Schema::Abilities::Result::RoleRole', 'role_id',
                      { cascade_copy => 0, cascade_delete => 0 });


 __PACKAGE__->has_many(map_role_parents => 'Schema::Abilities::Result::RoleRole', 'inherits_from_id',
                      { cascade_copy => 0, cascade_delete => 0 });

__PACKAGE__->many_to_many(actions => 'map_role_actions', 'action');
__PACKAGE__->many_to_many(roles   => 'map_role_roles',   'role');
__PACKAGE__->many_to_many(parents => 'map_role_parents', 'parent');

__PACKAGE__->meta->make_immutable;

1;