# encoding: utf-8
require 'github_api/s3_uploader'
module Github
class Repos::Downloads < API
REQUIRED_PARAMS = %w[ name size ]
VALID_DOWNLOAD_PARAM_NAMES = %w[
name
size
description
content_type
].freeze
# List downloads for a repository
#
# = Examples
# github = Github.new
# github.repos.downloads.list 'user-name', 'repo-name'
# github.repos.downloads.list 'user-name', 'repo-name' { |downl| ... }
#
def list(user_name, repo_name, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
normalize! params
response = get_request("/repos/#{user}/#{repo}/downloads", params)
return response unless block_given?
response.each { |el| yield el }
end
alias :all :list
# Get a single download
#
# = Examples
# github = Github.new
# github.repos.downloads.get 'user-name', 'repo-name', 'download-id'
#
def get(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
get_request("/repos/#{user}/#{repo}/downloads/#{download_id}", params)
end
alias :find :get
# Delete download from a repository
#
# = Examples
# github = Github.new
# github.repos.downloads.delete 'user-name', 'repo-name', 'download-id'
#
def delete(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
delete_request("/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.downloads.create 'user-name', 'repo-name',
# "name" => "new_file.jpg",
# "size" => 114034,
# "description" => "Latest release",
# "content_type" => "text/plain"
#
def create(user_name, repo_name, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
normalize! params
filter! VALID_DOWNLOAD_PARAM_NAMES, params
assert_required_keys(REQUIRED_PARAMS, params)
post_request("/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 resource of the create_download call.
# * :filename - Required filename, a path to a file location.
#
# = Examples
# resource = github.repos.downloads.create 'user-name', 'repo-name'
#
# github.repos.downloads.upload resource, '/users/octokit/image.jpg'
#
def upload(resource, filename)
_validate_presence_of resource, filename
response = Github::S3Uploader.new(resource, filename).send
response.body
end
alias :upload_to_s3 :upload
alias :upload_to_amazon :upload
end # Repos::Downloads
end # Github