NAME
WebService::NationBuilder - NationBuilder API bindings
VERSION
version 0.0107
SYNOPSIS
my
$nb
= WebService::NationBuilder->new(
access_token
=>
'abc123'
,
subdomain
=>
'testing'
,
);
$nb
->get_sites();
DESCRIPTION
This module provides bindings for the NationBuilder API.
METHODS
new
Instantiates a new WebService::NationBuilder client object.
my
$nb
= WebService::NationBuilder->new(
access_token
=>
$access_token
,
subdomain
=>
$subdomain
,
domain
=>
$domain
,
# optional
version
=>
$version
,
# optional
retries
=>
$retries
,
# optional
);
Parameters
- -
access_token
-
Required
A valid NationBuilder OAuth 2.0 access token for your nation.
- -
subdomain
-
Required
The NationBuilder subdomain (slug) for your nation.
- -
domain
-
Optional
The NationBuilder top-level domain to make API calls against. Defaults to nationbuilder.com.
- -
version
-
Optional
The NationBuilder API version to use. Defaults to
v1
. - -
retries
-
Optional
The number of times to retry requests in cases when Balanced returns a 5xx response. Defaults to
0
.
get_sites
Get information about the sites hosted by a nation.
Request:
get_sites({
page
=> 1,
per_page
=> 10,
});
Response:
[{
id
=> 1,
name
=>
'Foobar'
,
slug
=>
'foobar'
,
domain
=>
'foobarsoftwares.com'
,
},
{
id
=> 2,
name
=>
'Test Site'
,
slug
=>
'test'
,
domain
=>
undef
,
}]
get_people
Get a list of the people in a nation.
Request:
get_people({
page
=> 1,
per_page
=> 10,
});
Response:
[{
id
=> 1,
=>
'test@gmail.com'
phone
=>
'415-123-4567'
,
mobile
=>
'555-123-4567'
,
first_name
=>
'Firstname'
,
last_name
=>
'Lastname'
,
created_at
=>
'2013-12-08T04:27:12-08:00'
,
updated_at
=>
'2013-12-24T12:03:51-08:00'
,
sex
=>
undef
,
twitter_id
=>
'123456789'
,
primary_address
=> {
address1
=>
undef
,
address2
=>
undef
,
zip
=>
undef
,
city
=>
'San Francisco'
,
state
=>
'CA'
,
country_code
=>
'US'
,
lat
=>
'37.7749295'
,
lng
=>
'-122.4194155'
,
}
}]
get_person
Get a full representation of the person with the provided id
.
Request:
get_person(1);
Response:
{
id
=> 1,
=>
'test@gmail.com'
phone
=>
'415-123-4567'
,
mobile
=>
'555-123-4578'
,
first_name
=>
'Firstname'
,
last_name
=>
'Lastname'
,
created_at
=>
'2013-12-08T04:27:12-08:00'
,
updated_at
=>
'2013-12-24T12:03:51-08:00'
,
sex
=>
undef
,
twitter_id
=>
'123456789'
,
primary_address
=> {
address1
=>
undef
,
address2
=>
undef
,
zip
=>
undef
,
city
=>
'San Francisco'
,
state
=>
'CA'
,
country_code
=>
'US'
,
lat
=>
'37.7749295'
,
lng
=>
'-122.4194155'
,
}
}
match_person
Get a full representation of the person with certain attributes.
Request:
match_person({
=>
'test@gmail.com'
,
phone
=>
'415-123-4567'
,
mobile
=>
'555-123-4567'
,
first_name
=>
'Firstname'
,
last_name
=>
'Lastname'
,
});
Response:
{
id
=> 1,
=>
'test@gmail.com'
phone
=>
'415-123-4567'
,
mobile
=>
'555-123-4578'
,
first_name
=>
'Firstname'
,
last_name
=>
'Lastname'
,
created_at
=>
'2013-12-08T04:27:12-08:00'
,
updated_at
=>
'2013-12-24T12:03:51-08:00'
,
sex
=>
undef
,
twitter_id
=>
'123456789'
,
primary_address
=> {
address1
=>
undef
,
address2
=>
undef
,
zip
=>
undef
,
city
=>
'San Francisco'
,
state
=>
'CA'
,
country_code
=>
'US'
,
lat
=>
'37.7749295'
,
lng
=>
'-122.4194155'
,
}
}
create_person
Create a person with the provided data, and return a full representation of the person who was created.
Request:
create_person({
=>
'test@gmail.com'
,
phone
=>
'415-123-4567'
,
mobile
=>
'555-123-4567'
,
first_name
=>
'Firstname'
,
last_name
=>
'Lastname'
,
});
Response:
{
id
=> 1,
=>
'test@gmail.com'
phone
=>
'415-123-4567'
,
mobile
=>
'555-123-4578'
,
first_name
=>
'Firstname'
,
last_name
=>
'Lastname'
,
created_at
=>
'2013-12-08T04:27:12-08:00'
,
updated_at
=>
'2013-12-24T12:03:51-08:00'
,
sex
=>
undef
,
twitter_id
=>
undef
,
primary_address
=>
undef
,
}
update_person
Update the person with the provided id
to have the provided data, and return a full representation of the person who was updated.
Request:
update_person(1, {
=>
'test2@gmail.com'
,
phone
=>
'123-456-7890'
,
mobile
=>
'999-876-5432'
,
first_name
=>
'Firstname2'
,
last_name
=>
'Lastname2'
,
});
Response:
{
id
=> 1,
=>
'test2@gmail.com'
phone
=>
'123-456-7890'
,
mobile
=>
'999-876-5432'
,
first_name
=>
'Firstname2'
,
last_name
=>
'Lastname2'
,
created_at
=>
'2013-12-08T04:27:12-08:00'
,
updated_at
=>
'2013-12-24T12:03:51-08:00'
,
sex
=>
undef
,
twitter_id
=>
undef
,
primary_address
=>
undef
,
}
push_person
Update a person matched by email address, or create a new person if no match is found, then return a full representation of the person who was created or updated.
Request:
push_person({
=>
'test2@gmail.com'
,
sex
=>
'M'
,
first_name
=>
'Firstname3'
,
last_name
=>
'Lastname3'
,
});
Response:
{
id
=> 1,
=>
'test2@gmail.com'
phone
=>
'123-456-7890'
,
mobile
=>
'999-876-5432'
,
first_name
=>
'Firstname3'
,
last_name
=>
'Lastname3'
,
created_at
=>
'2013-12-08T04:27:12-08:00'
,
updated_at
=>
'2013-12-24T12:03:51-08:00'
,
sex
=>
'M'
,
twitter_id
=>
undef
,
primary_address
=>
undef
,
}
delete_person
Removes the person with the provided id
from the nation.
Request:
delete_person(1);
Response:
1
get_tags
Get the tags that have been used before in a nation.
Request:
get_tags({
page
=> 1,
per_page
=> 10,
});
Response:
[{
name
=>
'tag1'
,
},
{
name
=>
'tag2'
,
}]
get_person_tags
Gets a list of the tags for a given person with the provided id
.
Request:
get_person_tags(1);
Response:
[{
person_id
=> 1,
tag
=>
'tag1'
,
},
{
person_id
=> 1,
tag
=>
'tag2'
,
}]
set_tag
Associates a tag to a given person with the provided id
.
Request:
set_tag(1,
'tag3'
);
Response:
{
person_id
=> 1,
tag
=>
'tag3'
,
}
delete_tag
Removes a tag from a given person with the provided id
.
Request:
delete_tag(1,
'tag3'
);
Response:
1
AUTHOR
Ali Anari <ali@anari.me>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Crowdtilt, Inc..
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.