NAME
WWW::Contact - Get contacts/addressbook from Web
SYNOPSIS
use
WWW::Contact;
use
Data::Dumper;
# Get contacts from email providers.
my
$wc
= WWW::Contact->new();
my
@contacts
=
$wc
->get_contacts(
'fayland@gmail.com'
,
'password'
);
my
$errstr
=
$wc
->errstr;
if
(
$errstr
) {
die
$errstr
;
# like 'Wrong Username or Password'
}
else
{
Dumper(\
@contacts
);
}
# Get contacts from social networks (eg: Plaxo)
my
$ws
= WWW::Contact->new();
# Note that the last argument for get_contacts() is mandatory,
# or else it will try to fetch contacts from gmail.com
my
@contacts
=
$ws
->get_contacts(
'itsa@gmail.com'
,
'password'
,
'plaxo'
);
my
$errstr
=
$ws
->errstr;
if
(
$errstr
) {
die
$errstr
;
# like 'Wrong Username or Password'
}
else
{
Dumper(\
@contacts
);
}
DESCRIPTION
Get contacts/addressbook from public websites
SUPPORTED EMAIL SUPPLIER
- Gmail
-
WWW::Contact::Gmail by Fayland Lam, DEPRECATED for WWW::Contact::GoogleContactsAPI
- Yahoo! Mail
-
WWW::Contact::Yahoo by Fayland Lam
- Rediffmail
-
WWW::Contact::Rediffmail by Sachin Sebastian
- mail.163.com
-
WWW::Contact::CN::163 by Fayland Lam
- AOL
-
WWW::Contact::AOL by Fayland Lam
-
WWW::Contact::Mail by Sachin Sebastian
- Hotmail/Live Mail
-
WWW::Contact::Hotmail by Fayland Lam
- Indiatimes
-
WWW::Contact::Indiatimes by Sachin Sebastian
- Lycos
-
WWW::Contact::Lycos by Sachin Sebastian
- Plaxo
-
WWW::Contact::Plaxo by Sachin Sebastian
- GoogleContactsAPI
-
WWW::Contact::GoogleContactsAPI by Fayland Lam, using Google Contacts Data API
- abv.bg
-
WWW::Contact::BG::Abv by Dimitar Petrov
- mail.bg
-
WWW::Contact::BG::Mail by Dimitar Petrov
METHODS
register_supplier
To use custom supplier, we must register within WWW::Contact
$wc
->register_supplier(
qr/\@a\.com$/
,
'Unknown'
);
$wc
->register_supplier(
'a.com'
,
'Unknown'
);
The first arg is a Regexp or domain from email postfix. The second arg is the according module postfix like 'Unknown' from WWW::Contact::Unknown
get_supplier_by_email
get supplier by email.
my
$supplier
=
$wc
->get_supplier_by_email(
'a@gmail.com'
);
# 'GoogleContactsAPI'
my
$supplier
=
$wc
->get_supplier_by_email(
'a@a.com'
);
# 'Unknown'
get_supplier_by_socialnetwork
get supplier by social network name.
my
$supplier
=
$wc
->get_supplier_by_socialnetwork(
'plaxo'
);
# 'Plaxo'
HOW TO WRITE YOUR OWN MODULE
Please read WWW::Contact::Base and examples: WWW::Contact::Yahoo and WWW::Contact::Plaxo
Assuming we write a custom module as WWW::Contact::Unknown
package
WWW::Contact::Unknown;
use
Moose;
sub
get_contacts {
my
(
$self
,
,
$password
) =
@_
;
# reset
$self
->errstr(
undef
);
if
(
eq
'a@a.com'
and
$password
ne
'a'
) {
$self
->errstr(
'Wrong Username or Password'
);
return
;
}
my
@contacts
= ( {
=>
'b@b.com'
,
name
=>
'b'
,
}, {
=>
'c@c.com'
,
name
=>
'c'
} );
return
wantarray
?
@contacts
: \
@contacts
;
}
1;
We can use it within WWW::Contact
my
$wc
= WWW::Contact->new();
$wc
->register_supplier(
qr/\@a\.com$/
,
'Unknown'
);
# or
# $wc->register_supplier( 'a.com', 'Unknown' );
my
@contacts
=
$wc
->get_contacts(
'a@a.com'
,
'b'
);
my
$errstr
=
$wc
->errstr;
SEE ALSO
SUPPORTS
AUTHOR
Fayland Lam, <fayland at gmail.com>
Sachin Sebastian, <sachinjsk at cpan.org>
Dimitar Petrov, <mitakaa at gmail.com>
COPYRIGHT & LICENSE
Copyright 2008 *AUTHOR* all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.