+++ /dev/null
-# 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 <don@donarmstrong.com>.
-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__