]> git.donarmstrong.com Git - debbugs.git/blob - lib/Debbugs/DB/ResultSet/SrcPkg.pm
Debbugs::DB::Util is now a component of Debbugs::DB
[debbugs.git] / lib / Debbugs / DB / ResultSet / SrcPkg.pm
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>.
5 use utf8;
6 package Debbugs::DB::ResultSet::SrcPkg;
7
8 =head1 NAME
9
10 Debbugs::DB::ResultSet::SrcPkg - Source Package
11
12 =head1 SYNOPSIS
13
14
15
16 =head1 DESCRIPTION
17
18
19
20 =cut
21
22 use strict;
23 use warnings;
24
25 use base 'DBIx::Class::ResultSet';
26
27 sub src_pkg_and_ver_in_suite {
28     my ($self,$suite) = @_;
29     if (ref($suite)) {
30         if (ref($suite) eq 'HASH') {
31             $suite = $suite->{id}
32         } else {
33            $suite = $suite->id();
34         }
35     } else {
36         if ($suite !~ /^\d+$/) {
37             $suite = $self->result_source->schema->
38                 resultset('Suite')->
39                 search_rs({codename => $suite},
40                          {result_class => 'DBIx::Class::ResultClass::HashRefInflator',
41                          })->first();
42             if (defined $suite) {
43                 $suite = $suite->{id};
44             }
45         }
46     }
47     return
48         $self->search_rs({'src_associations.suite' => $suite,
49                          },
50                         {join => {src_vers => 'src_associations'},
51                          result_class => 'DBIx::Class::ResultClass::HashRefInflator',
52                          columns => [qw(me.pkg src_vers.ver src_associations.id)]
53                         },
54                         )->all;
55 }
56
57
58 sub get_src_pkg_id {
59     my ($self,$source) = @_;
60     return $self->result_source->schema->
61         select_one(<<'SQL',$source);
62 SELECT id FROM src_pkg where pkg = ?;
63 SQL
64 }
65
66 sub get_or_create_src_pkg_id {
67     my ($self,$source) = @_;
68     return $self->result_source->schema->
69         select_one(<<'SQL',$source,$source);
70 WITH ins AS (
71 INSERT INTO src_pkg (pkg)
72    VALUES (?) ON CONFLICT (pkg,disabled) DO NOTHING RETURNING id
73 )
74 SELECT id FROM ins
75 UNION ALL
76 SELECT id FROM src_pkg where pkg = ? AND disabled = 'infinity'::timestamptz
77 LIMIT 1;
78 SQL
79 }
80
81 1;
82
83 __END__