Re: plpgsql function to validate e-mail - Mailing list pgsql-general

From Pavel Stehule
Subject Re: plpgsql function to validate e-mail
Date
Msg-id 162867790908162143i337533c1k21107ec83d6e3b89@mail.gmail.com
Whole thread Raw
In response to plpgsql function to validate e-mail  (Andre Lopes <lopes80andre@gmail.com>)
Responses Re: plpgsql function to validate e-mail  (David Fetter <david@fetter.org>)
List pgsql-general
Hello

2009/8/16 Andre Lopes <lopes80andre@gmail.com>:
> Hi,
>
> I need a plpgsql function to validade e-mail addresses. I have google but I
> can't find any.
>
> My question: Anyone have a function to validate e-mails?
>
> Best Regards,
> André.
>

You don't need plpgsql. Important is only an using of regular expression.

very strong validation should be done via plperlu

CREATE OR REPLACE FUNCTION check_email(varchar)
RETURNS boolean AS $$
use strict;
use Email::Valid;
my $address = $_[0];
my $checks = {
   -address => $address,
   -mxcheck => 1,
   -tldcheck => 1,
   -rfc822 => 1,
};
if (defined Email::Valid->address( %$checks )) {
    return 'true'
}
elog(WARNING, "address failed $Email::Valid::Details check.");
return 'false';
$$ LANGUAGE plperlu IMMUTABLE STRICT;

postgres=# CREATE DOMAIN email AS varchar CHECK(check_email(value));
CREATE DOMAIN
postgres=# SELECT 'pavel@'::email;
WARNING:  address failed rfc822 check.
postgres=# select 'stehule@kix.fsv.cvut.cz'::email;
          email
-------------------------
 stehule@kix.fsv.cvut.cz
(1 row)

regards
Pavel Stehule

pgsql-general by date:

Previous
From: "Andrew Bartley"
Date:
Subject: Function Logging
Next
From: Craig Ringer
Date:
Subject: Re: Function Logging