NAME
WWW::Foursquare - is a Perl wrapper for the Foursqauare API.
VERSION
This document describes WWW::Foursquare version 0.9906
SYNOPSIS
use WWW::Foursquare;
# Create fs object
my $fs = WWW::Foursquare->new(
client_id => 'client_id',
client_secret => 'client_secret',
redirect_uri => 'redirect_uri',
);
# Set access_token
my $access_token = 'XXXX';
$fs->set_token($access_token);
# Search users by name
my $search_users = eval { $fs->users()->search(name => 'Pavel Vlasov') };
if (not $@) {
# work with result in Perl structure
# print Dumper($search_users);
}
else {
# process errors
warn $@ if $@;
}
DESCRIPTION
This wrapper help you send requests to Foursquare API and get result in easy way, OAuth is supported, quick integration with your current project. You can get more information about Foursquare API here: https://developer.foursquare.com/
INTEGRATION
How to connect your apps with foursquare via OAuth 2.0.
1. Create foursquare app:
https://foursquare.com/developers/apps
Get Client ID, Client Secret and Callback url
my $fs = WWW::Foursquare->new(
client_id => 'client_id',
client_secret => 'client_secret',
redirect_uri => 'redirect_uri',
);
2. Get auth url for your apps:
my $auth_url = $fs->get_auth_url();
It looks like this: https://foursquare.com/oauth2/authenticate?client_id=client_id&redirect_uri=redirect_url&response_type=code
3. Have a user authorize your app.
Implement callback in your server.
- You click on auth url to go to autorize page. - If authorization is successful you will redirect to callback url and get code. - Then you use this code for getting access_token for Foursquare API
http://your_server.com/callback&code=XXXXXXX
my $code = ... # getting code here
Allow app to access to your account in foursquare
my $access_token = $fs->get_access_token($code);
Background magic will send GET request to Foursquare API
4. Set access_token and using Foursquare API
$fs->set_access_token($access_token);
For more information I would recommend you visit page https://developer.foursquare.com/overview/auth
DEBUG MODE
my $fs = WWW::Foursquare->new(
debug => 1,
);
METHODS
new
Creating a new foursquare object.
my $fs = WWW::Foursquare->new(
client_id => 'client_id',
client_secret => 'client_secret',
redirect_uri => 'redirect_uri',
);
get_auth_url
Prepare auth url from Foursquare parameters (cliend_id, redirect_uri)
my $auth_url = $fs->get_auth_url();
get_access_token
Get code after redirect, and send GET request to fetch access token
my $access_token = $fs->get_access_token($code);
set_access_token
Set access token for foursquare object
$fs->set_access_token($code);
users
All users methods: https://developer.foursquare.com/docs/users/users
If you want to use itself method for forsquare API:
$fs->users->info(); # get info about users etc
venues
All venues methods: https://developer.foursquare.com/docs/venues/venues
venuegroups
All venuegroups methods: https://developer.foursquare.com/docs/venuegroups/venuegroups
checkins
All checkins methods: https://developer.foursquare.com/docs/checkins/checkins
tips
All tips methods: https://developer.foursquare.com/docs/tips/tips
lists
All lists methods: https://developer.foursquare.com/docs/lists/lists
updates
All updates methods: https://developer.foursquare.com/docs/updates/updates
photos
All photos methods: https://developer.foursquare.com/docs/photos/photos
settings
All settings methods: https://developer.foursquare.com/docs/settings/settings
specials
All specials methods: https://developer.foursquare.com/docs/specials/specials
campaigns
All campaigns methods: https://developer.foursquare.com/docs/campaigns/campaigns
events
All events methods: https://developer.foursquare.com/docs/events/events
pages
All pages methods: https://developer.foursquare.com/docs/pages/pages
pageupdates
All pageupdates methods: https://developer.foursquare.com/docs/pageupdates/pageupdates
EXAMPLES
You can see examples how to use WWW::Foursquare. Here: /eg/test.pl
AUTHOR
Pavel Vlasov, <fxzuz at cpan.org>
BUGS
Please report any bugs or feature requests to bug-www-foursquare at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=WWW-Foursquare. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc WWW::Foursquare
You can also look for information at:
Github
RT: CPAN's request tracker (report bugs here)
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
LICENSE AND COPYRIGHT
Copyright 2012 Pavel Vlasov.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.