# encoding: utf-8
module Github
class Repos
module Downloads
REQUIRED_PARAMS = %w[ name size ]
VALID_DOWNLOAD_PARAM_NAMES = %w[
name
size
description
content_type
].freeze
REQUIRED_S3_PARAMS = %w[
path
acl
name
accesskeyid
policy
signature
mime_type
].freeze
# Status code for successful upload to Amazon S3 service
SUCCESS_STATUS = 201
# List downloads for a repository
#
# = Examples
# @github = Github.new
# @github.repos.downloads 'user-name', 'repo-name'
# @github.repos.downloads 'user-name', 'repo-name' { |downl| ... }
#
def downloads(user_name=nil, repo_name=nil, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_normalize_params_keys(params)
response = get("/repos/#{user}/#{repo}/downloads", params)
return response unless block_given?
response.each { |el| yield el }
end
alias :list_downloads :downloads
alias :get_downloads :downloads
# Get a single download
#
# = Examples
# @github = Github.new
# @github.repos.download 'user-name', 'repo-name'
#
def download(user_name, repo_name, download_id, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of download_id
_normalize_params_keys(params)
get("/repos/#{user}/#{repo}/downloads/#{download_id}", params)
end
alias :get_download :download
# Delete download from a repository
#
# = Examples
# @github = Github.new
# @github.repos.delete_download 'user-name', 'repo-name', 'download-id'
#
def delete_download(user_name, repo_name, download_id, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of download_id
_normalize_params_keys(params)
delete("/repos/#{user}/#{repo}/downloads/#{download_id}", params)
end
# Creating a new download is a two step process.
# You must first create a new download resource using this method.
# Response from this method is to be used in #upload method.
#
# = Inputs
# * :name - Required string - name of the file that is being created.
# * :size - Required number - size of file in bytes.
# * :description - Optional string
# * :content_type - Optional string
#
# = Examples
# @github = Github.new
# @github.repos.create_download 'user-name', 'repo-name',
# "name" => "new_file.jpg",
# "size" => 114034,
# "description" => "Latest release",
# "content_type" => "text/plain"
#
def create_download(user_name=nil, repo_name=nil, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_normalize_params_keys(params)
_filter_params_keys(VALID_DOWNLOAD_PARAM_NAMES, params)
raise ArgumentError, "Required parameters are: #{REQUIRED_PARAMS.join(', ')}" unless _validate_inputs(REQUIRED_PARAMS, params)
post("/repos/#{user}/#{repo}/downloads", params)
end
# Upload a file to Amazon, using the reponse instance from
# Github::Repos::Downloads#create_download. This can be done by passing
# the response object as an argument to upload method.
#
# = Parameters
# * resource - Required Hashie::Mash -resource of the create_download call
# * :size - Required number - size of file in bytes.
#
def upload(resource, filename)
_validate_presence_of resource, filename
raise ArgumentError, 'Need to provied resource of Github::Repose::Downloads#create_download call' unless resource.is_a? Hashie::Mash
REQUIRED_S3_PARAMS.each do |key|
raise ArgumentError, "Expected following key: #{key}" unless resource.respond_to?(key)
end
# TODO use ordered hash if Ruby < 1.9
hash = ruby_18 {
require 'active_support'
ActiveSupport::OrderedHash.new } || ruby_19 { Hash.new }
mapped_params = {
'key' => resource.path,
'acl' => resource.acl,
'success_action_status' => SUCCESS_STATUS,
'Filename' => resource.name,
'AWSAccessKeyId' => resource.accesskeyid,
'Policy' => resource.policy,
'Signature' => resource.signature,
'Content-Type' => resource.mime_type,
'file' => prepend_at_for(filename.to_s)
}
post('', mapped_params, { :url => resource.s3_url })
end
alias :upload_to_s3 :upload
alias :upload_to_amazon :upload
private
def prepend_at_for(file)
/^@.*/ =~ file ? '@' + file : file
end
end # Downloads
end # Repos
end # Github