forked from lix-project/hydra
002ac9ef63
The catalyst-action-rest branch from shlevy/hydra was an exploration of using Catalyst::Action::REST to create a JSON API for hydra. This commit merges in the best bits from that experiment, with the goal that further API endpoints can be added incrementally. In addition to migrating more endpoints, there is potential for improvement in what's already been done: * The web interface can be updated to use the same non-GET endpoints as the JSON interface (using x-tunneled-method) instead of having a separate endpoint * The web rendering should use the $c->stash->{resource} data structure where applicable rather than putting the same data in two places in the stash * Which columns to render for each endpoint is a completely debatable question * Hydra::Component::ToJSON should turn has_many relations that have strings as their primary keys into objects instead of arrays Fixes NixOS/hydra#98 Signed-off-by: Shea Levy <shea@shealevy.com>
158 lines
2.4 KiB
Perl
158 lines
2.4 KiB
Perl
use utf8;
|
|
package Hydra::Schema::BuildProducts;
|
|
|
|
# Created by DBIx::Class::Schema::Loader
|
|
# DO NOT MODIFY THE FIRST PART OF THIS FILE
|
|
|
|
=head1 NAME
|
|
|
|
Hydra::Schema::BuildProducts
|
|
|
|
=cut
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use base 'DBIx::Class::Core';
|
|
|
|
=head1 COMPONENTS LOADED
|
|
|
|
=over 4
|
|
|
|
=item * L<Hydra::Component::ToJSON>
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
__PACKAGE__->load_components("+Hydra::Component::ToJSON");
|
|
|
|
=head1 TABLE: C<BuildProducts>
|
|
|
|
=cut
|
|
|
|
__PACKAGE__->table("BuildProducts");
|
|
|
|
=head1 ACCESSORS
|
|
|
|
=head2 build
|
|
|
|
data_type: 'integer'
|
|
is_foreign_key: 1
|
|
is_nullable: 0
|
|
|
|
=head2 productnr
|
|
|
|
data_type: 'integer'
|
|
is_nullable: 0
|
|
|
|
=head2 type
|
|
|
|
data_type: 'text'
|
|
is_nullable: 0
|
|
|
|
=head2 subtype
|
|
|
|
data_type: 'text'
|
|
is_nullable: 0
|
|
|
|
=head2 filesize
|
|
|
|
data_type: 'bigint'
|
|
is_nullable: 1
|
|
|
|
=head2 sha1hash
|
|
|
|
data_type: 'text'
|
|
is_nullable: 1
|
|
|
|
=head2 sha256hash
|
|
|
|
data_type: 'text'
|
|
is_nullable: 1
|
|
|
|
=head2 path
|
|
|
|
data_type: 'text'
|
|
is_nullable: 1
|
|
|
|
=head2 name
|
|
|
|
data_type: 'text'
|
|
is_nullable: 0
|
|
|
|
=head2 description
|
|
|
|
data_type: 'text'
|
|
is_nullable: 1
|
|
|
|
=head2 defaultpath
|
|
|
|
data_type: 'text'
|
|
is_nullable: 1
|
|
|
|
=cut
|
|
|
|
__PACKAGE__->add_columns(
|
|
"build",
|
|
{ data_type => "integer", is_foreign_key => 1, is_nullable => 0 },
|
|
"productnr",
|
|
{ data_type => "integer", is_nullable => 0 },
|
|
"type",
|
|
{ data_type => "text", is_nullable => 0 },
|
|
"subtype",
|
|
{ data_type => "text", is_nullable => 0 },
|
|
"filesize",
|
|
{ data_type => "bigint", is_nullable => 1 },
|
|
"sha1hash",
|
|
{ data_type => "text", is_nullable => 1 },
|
|
"sha256hash",
|
|
{ data_type => "text", is_nullable => 1 },
|
|
"path",
|
|
{ data_type => "text", is_nullable => 1 },
|
|
"name",
|
|
{ data_type => "text", is_nullable => 0 },
|
|
"description",
|
|
{ data_type => "text", is_nullable => 1 },
|
|
"defaultpath",
|
|
{ data_type => "text", is_nullable => 1 },
|
|
);
|
|
|
|
=head1 PRIMARY KEY
|
|
|
|
=over 4
|
|
|
|
=item * L</build>
|
|
|
|
=item * L</productnr>
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
__PACKAGE__->set_primary_key("build", "productnr");
|
|
|
|
=head1 RELATIONS
|
|
|
|
=head2 build
|
|
|
|
Type: belongs_to
|
|
|
|
Related object: L<Hydra::Schema::Builds>
|
|
|
|
=cut
|
|
|
|
__PACKAGE__->belongs_to(
|
|
"build",
|
|
"Hydra::Schema::Builds",
|
|
{ id => "build" },
|
|
{ is_deferrable => 0, on_delete => "CASCADE", on_update => "NO ACTION" },
|
|
);
|
|
|
|
|
|
# Created by DBIx::Class::Schema::Loader v0.07033 @ 2013-06-13 01:54:50
|
|
# DO NOT MODIFY THIS OR ANYTHING ABOVE! md5sum:+0LkZiaRL5tGJvbLxnwD/g
|
|
|
|
# You can replace this text with custom content, and it will be preserved on regeneration
|
|
1;
|