A dropbox api interface
Version 1.9.8
The Dropbox \s-1API\s0 is a OAuth based \s-1API\s0. I try to abstract as much away as possible so you should not need to know too much about it. This is how it works:
use Net::Dropbox::API; my $box = Net::Dropbox::API->new({key => 'KEY', secret => 'SECRET'}); my $login_link = $box->login; # user needs to click this link and login $box->auth; # oauth keys get exchanged my $info = $box->account_info; # and here we have our account info
See the examples for a working Mojolicious web client using the Dropbox \s-1API\s0.
You can find Dropbox's \s-1API\s0 documentation at <https://www.dropbox.com/developers/web_docs>
This sets up the initial OAuth handshake and returns the login \s-1URL\s0. This \s-1URL\s0 has to be clicked by the user and the user then has to accept the application in dropbox.
Dropbox then redirects back to the callback \s-1URL\s0 defined with \*(C`$self->callback_url\*(C'. If the user already accepted the application the redirect may happen without the user actually clicking anywhere.
The auth method changes the initial request token into access token that we need for subsequent access to the \s-1API\s0. This method only has to be called once after login.
account_info polls the users info from dropbox.
lists all files in the path defined:
$data = $box->list(); # top-level $data = $box->list( "/Photos" ); # folder
The data returned is a ref to a hash containing various fields returned by Dropbox, including a \*(C`hash\*(C' value, which can be used later to check if Dropbox data beneath a specified folder has changed since the last call.
For this, \*(C`list()\*(C' accepts an optional 'hash' argument:
$data = $box->list({ hash => "ce9ccbfb8f255f234c93adcfef33b5a6" }, "/Photos");
This will either return
{ http_response_code => 304 }
in which case nothing has changed since the last call, or
{ http_response_code => 200, # ... various other fields }
if there were modifications.
copies a folder
copy($from, $to)
move a folder
move($from, $to)
creates a folder
mkdir($path)
delete a folder
delete($path)
creates a cookie protected link for the user to look at.
view($path)
creates a cookie protected link for the user to look at.
metadata($path)
uploads a file to dropbox
get a file from dropbox
Set this to a non-false value in order to print some debugging information to \s-1STDOUT\s0.
debug\|(1)
_talk handles the access to the restricted resources. You should normally not need to access this directly.
Generate a different nonce for every request.
Lenz Gschwendtner, \*(C`<norbu09 at cpan.org>\*(C'
With Bug fixes from:
Greg Knauss \*(C`gknauss at eod.com\*(C'
Chris Prather \*(C`chris at prather.org\*(C'
Shinichiro Aska
[ktdreyer]
SureVoIP <http://www.surevoip.co.uk>
Please report any bugs through the web interface at https://github.com/norbu09/Net\*(--Dropbox/issues <https://github.com/norbu09/Net--Dropbox/issues>. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
You can find documentation for this module with the perldoc command.
perldoc Net::Dropbox::API
You can also look for information at:
AnnoCPAN: Annotated \s-1CPAN\s0 documentation http://annocpan.org/dist/Net-Dropbox-API <http://annocpan.org/dist/Net-Dropbox-API>
\s-1CPAN\s0 Ratings http://cpanratings.perl.org/d/Net-Dropbox-API <http://cpanratings.perl.org/d/Net-Dropbox-API>
Search \s-1CPAN\s0 http://search.cpan.org/dist/Net-Dropbox-API/ <http://search.cpan.org/dist/Net-Dropbox-API/>
Copyright 2010 Lenz Gschwendtner.
This program is free software; you can redistribute it and/or modify it under the terms of either: the \s-1GNU\s0 General Public License as published by the Free Software Foundation; or the Artistic License.
See http://dev.perl.org/licenses/ for more information.