The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
NAME
    Net::UpYun - Simple client library for UpYun Restful API.

SYNOPSIS
        # Yes, I love modern perl!
        use v5.12;
        use Net::UpYun;
    
        my $upyun = Net::UpYun->new(
            bucket_account => 'xxxxx',
            bucket_password => 'xxxx',
            bucket => 'bucket_name',
            # optional
            api_domain => 'http://v0.api.upyun.com',
        );

        # get bucket/folder/file usage
        my $usage = $upyun->usage;
        # or folder/file
        say $upyun->usage('/demo');

        # switch bucket
        $upyun->use_bucket('bucket_new');
        # use different account/password
        $upyun->use_bucket('bucket_new',$new_account,$new_password);

        # create dir
        my $ok = $upyun->mkdir('/demo2');

        # list file under the directory
        my $files = $upyun->list('/demo2');

        # rm dir
        my $ok = $upyun->rmdir('/demo2');

        # upload file
        my $ok = $upyun->put($file_key,$file_bytes);

        # get file content
        my $bytes = $upyun->get($file_key);

        # delete file
        $upyun->delete($file_key);

        # change api domaim
        $upyun->api_domain('http://v1.api.upyun.com');

DESCRIPTION
    This module provides very simple interfaces to UpYun Cloud servie,for
    more details about UpYun storage/CDN clound service, see
    <http://www.upyun.com/>.

    This module uses WWW::Curl and libcurl for best performance, I just test
    on Mac Lion and Linux, maybe works on Windows/Cygwin.

METHODS
  new()
    bucket
    bucket_account
    bucket_password
    api_domain

  usage($path)
        # whole bucket used storage
        $upyun->usage;
        # some dir/folder
        say $upyun->usage('/dir1');
        # some file size
        say $upyun->usage('/dir1/demo1.jpg');

    List bucket or path(folder or file) used space.

  use_bucket($new_bucket_name,$new_account?,$new_password?)
        # switch to new bucket,account/password same as current
        $upyun->use_bucket('bucket2');
        # switch to new bucket, also set new account/password
        $upyun->use_bucket('bucket3','new_user','new_password');

    Switch to another bucket, if omit new_account,new_password, use previous
    defined.

  mkdir($path)
        my $ok = $upyun->mkdir('/path1/path2');

    Build directory or path.

  rmdir($path)
        my $ok = $upyun->rmdir('/path1');

    Delete the directory, it must be empty.

  list($path)
        my $dir_content_str = $upyun->list('/');

    List files under the directory.

    TODO: $dir_content_str is plain text, need to parse.

  put($path,$bytes)
        # it will auto mkdir.
        my $ok = $upyun->put('/demo/1.txt','okokok');

    Upload content to the file, it will auto create directories.

    NOTE: According UpYun note, max directories deep level is limited to 10,
    be careful.

  get($path)
        say $upyun->get('/demo/1.txt');

    Get the file content.

  delete($path)
        my $ok = $upyun->delete('/demo/1.txt');

    Delete the file.

  reponse
        my $http_response = $upyun->response;

    Returns latest response,it's an instance of HTTP::Response.

  res_content
    Raw response content body.

  is_success
  is_error
    These methods indicate if the response was informational, successful, or
    an error. If the response code was 2xx code, is_success is true, else
    is_error is true.

  error_code
    The code is a 3 digit number that encode the overall outcome of the last
    HTTP response.

  error_message
    The message is a short human readable single line string that explains
    the last response code.

  do_request
    Internal, send signed request to server.

  sign
    Private.

TODOS
    Much jobs to do.

    *   handy client shell.

    *   copy/move file under same bucket or between different bucket.

    *   simple check file exists on remote ,no need to fetch its
        content,save bandwidth.

    *   display/compare files checksum(MD5) local and remote.

    *   streaming upload to save memory.

    *   useful utility, like tar/untar to/from upyun on fly.

    *   multi operation and performance requests in parallel.

    *   code clean and refactory.

AUTHOR
    Night Sailer(Pan Fan) <nightsailer{at}gmail_dot_com>

COPYRIGHT
    Copyright (C) Pan Fan(nightsailer)

LICENSE
    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.