]> git.donarmstrong.com Git - debbugs.git/blobdiff - Debbugs/DB/ResultSet/Correspondent.pm
move Debbugs to lib
[debbugs.git] / Debbugs / DB / ResultSet / Correspondent.pm
diff --git a/Debbugs/DB/ResultSet/Correspondent.pm b/Debbugs/DB/ResultSet/Correspondent.pm
deleted file mode 100644 (file)
index d722a5f..0000000
+++ /dev/null
@@ -1,92 +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 <don@donarmstrong.com>.
-use utf8;
-package Debbugs::DB::ResultSet::Correspondent;
-
-=head1 NAME
-
-Debbugs::DB::ResultSet::Correspondent - Correspondent table actions
-
-=head1 SYNOPSIS
-
-
-
-=head1 DESCRIPTION
-
-
-
-=cut
-
-use strict;
-use warnings;
-
-use base 'DBIx::Class::ResultSet';
-
-use Debbugs::DB::Util qw(select_one);
-
-use Debbugs::Common qw(getparsedaddrs);
-use Debbugs::DB::Util qw(select_one);
-use Scalar::Util qw(blessed);
-
-sub get_correspondent_id {
-    my ($self,$addr) = @_;
-    my $full_name;
-    if (blessed($addr)) {
-       $full_name = $addr->phrase();
-       $addr = $addr->address();
-    } elsif ($addr =~ /</) {
-       $addr = getparsedaddrs($addr);
-       $full_name = $addr->phrase();
-       $addr = $addr->address();
-    }
-    if (defined $full_name) {
-       $full_name =~ s/^\"|\"$//g;
-       $full_name =~ s/^\s+|\s+$//g;
-    }
-    my $rs =
-       $self->
-       search({addr => $addr},
-             {result_class => 'DBIx::Class::ResultClass::HashRefInflator',
-             }
-             )->first();
-    if (defined $rs) {
-       return $rs->{id};
-    }
-    return $self->result_source->schema->storage->
-       dbh_do(sub {
-                  my ($s,$dbh,$addr,$full_name) = @_;
-                  my $ci = select_one($dbh,<<'SQL',$addr,$addr);
-WITH ins AS (
-INSERT INTO correspondent (addr) VALUES (?)
- ON CONFLICT (addr) DO NOTHING RETURNING id
-)
-SELECT id FROM ins
-UNION ALL
-SELECT id FROM correspondent WHERE addr = ?
-LIMIT 1;
-SQL
-                  if (defined $full_name) {
-                      select_one($dbh,<<'SQL',$ci,$full_name);
-WITH ins AS (
-INSERT INTO correspondent_full_name (correspondent,full_name)
-   VALUES (?,?) ON CONFLICT (correspondent,full_name) DO NOTHING RETURNING 1
-) SELECT 1 FROM ins
-UNION ALL
-SELECT 1;
-SQL
-                  }
-                  return $ci;
-},
-              $addr,
-              $full_name
-             );
-
-}
-
-
-
-1;
-
-__END__