1 # This module is part of debbugs, and is released
2 # under the terms of the GPL version 2, or any later version. See the
3 # file README and COPYING for more information.
4 # Copyright 2017 by Don Armstrong <don@donarmstrong.com>.
6 package Debbugs::DB::ResultSet::SrcPkg;
10 Debbugs::DB::ResultSet::SrcPkg - Source Package
25 use base 'DBIx::Class::ResultSet';
27 use Debbugs::DB::Util qw(select_one);
29 sub src_pkg_and_ver_in_suite {
30 my ($self,$suite) = @_;
32 if (ref($suite) eq 'HASH') {
35 $suite = $suite->id();
38 if ($suite !~ /^\d+$/) {
39 $suite = $self->result_source->schema->
41 search_rs({codename => $suite},
42 {result_class => 'DBIx::Class::ResultClass::HashRefInflator',
45 $suite = $suite->{id};
50 $self->search_rs({'src_associations.suite' => $suite,
52 {join => {src_vers => 'src_associations'},
53 result_class => 'DBIx::Class::ResultClass::HashRefInflator',
54 columns => [qw(me.pkg src_vers.ver src_associations.id)]
61 my ($self,$source) = @_;
62 return $self->result_source->schema->storage->
64 my ($s,$dbh,$src_pkg) = @_;
65 return select_one($dbh,<<'SQL',$src_pkg);
66 SELECT id FROM src_pkg where pkg = ?;
73 sub get_or_create_src_pkg_id {
74 my ($self,$source) = @_;
75 return $self->result_source->schema->storage->
77 my ($s,$dbh,$source) = @_;
78 return select_one($dbh,<<'SQL',$source,$source);
80 INSERT INTO src_pkg (pkg)
81 VALUES (?) ON CONFLICT (pkg,disabled) DO NOTHING RETURNING id
85 SELECT id FROM src_pkg where pkg = ? AND disabled = 'infinity'::timestamptz