X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=Debbugs%2FDB%2FResultSet%2FSrcPkg.pm;fp=Debbugs%2FDB%2FResultSet%2FSrcPkg.pm;h=0000000000000000000000000000000000000000;hb=1e6633a3780f4fd53fc4303852e84d13cdad2dc6;hp=36fab13e50574e8827088a4d5e56b62a6cb19363;hpb=466f7faff129a5699c7674f59900a92aa256175d;p=debbugs.git diff --git a/Debbugs/DB/ResultSet/SrcPkg.pm b/Debbugs/DB/ResultSet/SrcPkg.pm deleted file mode 100644 index 36fab13..0000000 --- a/Debbugs/DB/ResultSet/SrcPkg.pm +++ /dev/null @@ -1,95 +0,0 @@ -# This module is part of debbugs, and is released -# under the terms of the GPL version 2, or any later version. See the -# file README and COPYING for more information. -# Copyright 2017 by Don Armstrong . -use utf8; -package Debbugs::DB::ResultSet::SrcPkg; - -=head1 NAME - -Debbugs::DB::ResultSet::SrcPkg - Source Package - -=head1 SYNOPSIS - - - -=head1 DESCRIPTION - - - -=cut - -use strict; -use warnings; - -use base 'DBIx::Class::ResultSet'; - -use Debbugs::DB::Util qw(select_one); - -sub src_pkg_and_ver_in_suite { - my ($self,$suite) = @_; - if (ref($suite)) { - if (ref($suite) eq 'HASH') { - $suite = $suite->{id} - } else { - $suite = $suite->id(); - } - } else { - if ($suite !~ /^\d+$/) { - $suite = $self->result_source->schema-> - resultset('Suite')-> - search_rs({codename => $suite}, - {result_class => 'DBIx::Class::ResultClass::HashRefInflator', - })->first(); - if (defined $suite) { - $suite = $suite->{id}; - } - } - } - return - $self->search_rs({'src_associations.suite' => $suite, - }, - {join => {src_vers => 'src_associations'}, - result_class => 'DBIx::Class::ResultClass::HashRefInflator', - columns => [qw(me.pkg src_vers.ver src_associations.id)] - }, - )->all; -} - - -sub get_src_pkg_id { - my ($self,$source) = @_; - return $self->result_source->schema->storage-> - dbh_do(sub { - my ($s,$dbh,$src_pkg) = @_; - return select_one($dbh,<<'SQL',$src_pkg); -SELECT id FROM src_pkg where pkg = ?; -SQL - }, - $source - ); -} - -sub get_or_create_src_pkg_id { - my ($self,$source) = @_; - return $self->result_source->schema->storage-> - dbh_do(sub { - my ($s,$dbh,$source) = @_; - return select_one($dbh,<<'SQL',$source,$source); -WITH ins AS ( -INSERT INTO src_pkg (pkg) - VALUES (?) ON CONFLICT (pkg,disabled) DO NOTHING RETURNING id -) -SELECT id FROM ins -UNION ALL -SELECT id FROM src_pkg where pkg = ? AND disabled = 'infinity'::timestamptz -LIMIT 1; -SQL - }, - $source - ); -} - -1; - -__END__