Mail-DMARC
view release on metacpan or search on metacpan
lib/Mail/DMARC/Report/Store/SQL/Grammars/PostgreSQL.pm view on Meta::CPAN
sub insert_rr_dkim {
my ( $self, $fields ) = @_;
my $fields_str = join '", "', @$fields;
return <<"EO_DKIM"
INSERT INTO "report_record_dkim"
("report_record_id", \"$fields_str\")
VALUES (??)
EO_DKIM
;
}
sub insert_rr_spf {
my ( $self, $fields ) = @_;
my $fields_str = join '", "', @$fields;
return "INSERT INTO \"report_record_spf\" (\"report_record_id\", \"$fields_str\") VALUES(??)";
}
sub insert_rr {
return <<'EO_ROW_INSERT'
INSERT INTO report_record
(report_id, source_ip, count, header_from_did, envelope_to_did, envelope_from_did,
disposition, dkim, spf)
VALUES (??)
EO_ROW_INSERT
;
}
sub insert_policy_published {
return <<"EO_RPP"
INSERT INTO report_policy_published
(report_id, adkim, aspf, p, sp, pct, rua)
VALUES (??)
EO_RPP
;
}
sub select_from {
my ($self, $columns, $table) = @_;
my $colStr = '*';
if ( @{$columns}[0] ne '*' ) {
my @cols;
foreach my $col (@$columns) {
if ( $col =~ /(\w+)(?:\s+as\s+(\w+))/i ) {
$col = "$1\" AS \"$2";
}
$col = "\"$col\"";
push @cols, $col;
}
$colStr = join( ', ', @cols );
}
return "SELECT $colStr FROM \"$table\" WHERE 1=1";
}
sub insert_into {
my ($self, $table, $cols) = @_;
my $columns = '"' . join( '", "', @$cols ) . '"';
return "INSERT INTO \"$table\" ($columns) VALUES (??)";
}
sub update {
my ($self, $table, $cols) = @_;
my $columns = '"' . join( '" = ?, "') . '" = ?';
return "UPDATE \"$table\" SET $columns WHERE 1=1";
}
sub delete_from {
my ($self, $table) = @_;
return "DELETE FROM \"$table\" WHERE 1=1";
}
sub replace_into {
my ($self, $table, $cols) = @_;
my $insertColumns = '"' . join( '", "', @$cols ) . '"';
my @ucols;
foreach my $col (@$cols) {
push @ucols, "\"$col\" = EXCLUDED.\"$col\""
}
my $updateColumns = join ', ', @ucols;
return "INSERT INTO \"$table\" ($insertColumns) VALUES (??)
ON CONFLICT ($insertColumns) DO UPDATE SET $updateColumns";
}
1;
__END__
=pod
=head1 NAME
Mail::DMARC::Report::Store::SQL::Grammars::PostgreSQL - Grammar for working with pgsql databases.
=head1 VERSION
version 1.20260306
=head1 SYPNOSIS
Allow DMARC to be able to speak to PostgreSQL databases.
=head1 DESCRIPTION
=head1 AUTHORS
=over 4
=item *
Matt Simerson <msimerson@cpan.org>
=item *
Davide Migliavacca <shari@cpan.org>
=item *
Marc Bradshaw <marc@marcbradshaw.net>
=back
( run in 0.595 second using v1.01-cache-2.11-cpan-39bf76dae61 )