package PkgForge::Registry::Schema::Result::Job; # -*- perl -*-
use strict;
use warnings;
# $Id: Job.pm.in 16917 2011-05-02 12:53:11Z squinney@INF.ED.AC.UK $
# $Source:$
# $Revision: 16917 $
# $HeadURL: https://svn.lcfg.org/svn/source/tags/PkgForge-Registry/PkgForge_Registry_1_3_0/lib/PkgForge/Registry/Schema/Result/Job.pm.in $
# $Date: 2011-05-02 13:53:11 +0100 (Mon, 02 May 2011) $
our $VERSION = '1.3.0';
use DateTime;
use base 'DBIx::Class::Core';
=head1 NAME
PkgForge::Registry::Schema::Result::Job
=head1 VERSION
This documentation refers to PkgForge::Registry::Schema::Result::Job version 1.3.0
=cut
__PACKAGE__->load_components(qw/InflateColumn::DateTime Core/);
__PACKAGE__->table('job');
=head1 ACCESSORS
=head2 id
data_type: 'integer'
is_auto_increment: 1
is_nullable: 0
sequence: 'job_id_seq'
=head2 uuid
data_type: 'varchar'
is_nullable: 0
size: 50
=head2 submitter
data_type: 'varchar'
is_nullable: 1
size: 50
=head2 modtime
data_type: 'timestamp with time zone'
default_value: current_timestamp
is_nullable: 0
original: {default_value => \'now()'}
=head2 size
data_type: 'integer'
is_foreign_key: 0
is_nullable: 1
=head2 status
data_type: 'integer'
default_value: 0
is_foreign_key: 1
is_nullable: 0
=cut
__PACKAGE__->add_columns(
'id',
{
data_type => 'integer',
is_auto_increment => 1,
is_nullable => 0,
sequence => 'job_id_seq',
},
'uuid',
{ data_type => 'varchar', is_nullable => 0, size => 50 },
'submitter',
{ data_type => 'varchar', is_nullable => 1, size => 50 },
'modtime',
{
data_type => 'datetime',
is_foreign_key => 0,
is_nullable => 0,
},
'size',
{
data_type => 'integer',
is_foreign_key => 0,
is_nullable => 1,
},
'status',
{
data_type => 'integer',
default_value => 0,
is_foreign_key => 1,
is_nullable => 0,
},
);
__PACKAGE__->set_primary_key('id');
__PACKAGE__->add_unique_constraint('job_uuid_key', ['uuid']);
=head1 RELATIONS
=head2 status
Type: belongs_to
Related object: L<PkgForge::Registry::Schema::Result::JobStatus>
=cut
__PACKAGE__->belongs_to(
'status',
'PkgForge::Registry::Schema::Result::JobStatus',
{ id => 'status' },
{ on_delete => 'CASCADE', on_update => 'CASCADE' },
);
=head2 tasks
Type: has_many
Related object: L<PkgForge::Registry::Schema::Result::Task>
=cut
__PACKAGE__->has_many(
'tasks',
'PkgForge::Registry::Schema::Result::Task',
{ 'foreign.job' => 'self.id' },
{ cascade_copy => 0, cascade_delete => 0 },
);
=head2 build_logs
Type: has_many
Related object: L<PkgForge::Registry::Schema::Result::BuildLog>
=cut
__PACKAGE__->has_many(
'build_logs',
'PkgForge::Registry::Schema::Result::BuildLog',
{ 'foreign.job' => 'self.uuid' },
{ cascade_copy => 0, cascade_delete => 0 },
);
1;
__END__
=head1 DEPENDENCIES
This module requires L<DBIx::Class>, it also needs L<DateTime> to
inflate the C<modtime> column into something useful.
=head1 SEE ALSO
L<PkgForge::Registry>, L<PkgForge::Registry::Schema>
=head1 PLATFORMS
This is the list of platforms on which we have tested this
software. We expect this software to work on any Unix-like platform
which is supported by Perl.
ScientificLinux5, Fedora13
=head1 BUGS AND LIMITATIONS
Please report any bugs or problems (or praise!) to bugs@lcfg.org,
feedback and patches are also always very welcome.
=head1 AUTHOR
Stephen Quinney <squinney@inf.ed.ac.uk>
=head1 LICENSE AND COPYRIGHT
Copyright (C) 2010 University of Edinburgh. All rights reserved.
This library is free software; you can redistribute it and/or modify
it under the terms of the GPL, version 2 or later.
=cut