1 require 'osdn/cli/command/frs_base'
4 module OSDN; module CLI; module Command
5 class Relfile < FrsBase
7 puts "#{$0} relfile [opts] [list]"
8 puts "#{$0} relfile [opts] create <target-file> [target-files...]"
9 puts "#{$0} relfile [opts] update <numeric-file-id>"
10 puts "#{$0} relfile [opts] delete <numeric-file-id>"
12 puts " -f --format=<pretty|json> Set output format"
13 puts " -p --project=<project> Target project (numeric id or name)"
14 puts " --package=<package-id> Target package (numeric id)"
15 puts " --release=<release-id> Target release (numeric id)"
16 puts " -v --visibility=<public|private|hidden>"
17 puts " --force-digest Calc local file digest forcely"
18 puts " --progress Force to show upload progress"
19 puts " --no-progress Force to hide upload progress"
20 puts " --bwlimit=RATE Limit bandwidth (in KB)"
24 "Manipulate frs files of project"
28 opts = GetoptLong.new(
29 [ '--format', '-f', GetoptLong::REQUIRED_ARGUMENT ],
30 [ '--project', '-p', GetoptLong::REQUIRED_ARGUMENT ],
31 [ '--package', GetoptLong::REQUIRED_ARGUMENT ],
32 [ '--release', GetoptLong::REQUIRED_ARGUMENT ],
33 [ '--visibility', '-v', GetoptLong::REQUIRED_ARGUMENT ],
34 [ '--force-digest', GetoptLong::NO_ARGUMENT],
35 [ '--progress', GetoptLong::NO_ARGUMENT],
36 [ '--no-progress', GetoptLong::NO_ARGUMENT],
37 [ '--bwlimit', GetoptLong::REQUIRED_ARGUMENT ],
39 opts.each do |opt, arg|
56 unless %w(public private hidden).member?(arg)
57 logger.fatal "Invalid visibility status: #{arg}"
64 @show_progress = false
67 OSDN::CLI._rate_limit = arg.to_i * 1024
73 release = api.get_release target_proj, target_package, target_release
76 puts list.map{|i| i.to_hash}.to_json
85 if ARGV.empty? || ARGV.first == ""
86 logger.fatal "Target filename is missing."
96 def create_one(filename)
97 file = Pathname('.') + filename
98 logger.debug "Calculating digest for #{file}..."
100 vars = load_variables(file.dirname)
102 if !@force_digest && vars.local_file_info &&
103 vars.local_file_info[file.basename.to_s]
104 finfo = vars.local_file_info[file.basename.to_s]
105 if finfo[:size] == file.size && finfo.mtime == file.mtime
106 digests = vars.local_file_info[file.basename.to_s].digests
111 logger.info "Calculating digest for #{file}..."
113 sha256: hexdigest(Digest::SHA256, file),
114 sha1: hexdigest(Digest::SHA1, file),
115 md5: hexdigest(Digest::MD5, file),
117 update_variables file.dirname, {local_file_info: {file.basename.to_s => {digests: digests, mtime: file.mtime, size: file.size}}}
121 logger.level <= Logger::INFO && @show_progress != false || @show_progress and
122 OSDN::CLI._show_progress = true
123 logger.info "Starting upload #{file}..."
129 f = api.create_release_file target_proj, target_package, target_release, fio, visibility: @visibility
130 rescue OSDNClient::ApiError => e
131 if max_upload_tries - upload_tries <= 0
132 logger.error "Max upload attempts (#{max_upload_tries}) has been exceeded, give up!"
134 elsif [0, 100, 502].member?(e.code.to_i)
136 logger.error "Upload error (#{e.code} #{e.message}), retrying (#{upload_tries}/#{max_upload_tries})..."
144 OSDN::CLI._show_progress = false
147 if digests.find { |type, dig| dig != f.send("digest_#{type}") }
148 logger.error "File digests are mismatch! Upload file #{file} may be broken! Please check."
150 logger.info "Upload complete."
156 target_id = ARGV.shift
158 logger.fatal "Target file ID is missing."
163 logger.fatal "Visibility status is missing. Use '-v <public|private|hidden>'."
166 f = api.update_release_file target_proj, target_package, target_release, target_id, visibility: @visibility
167 logger.info "file #{target_id} has been updated."
172 target_id = ARGV.shift
174 logger.fatal "Target file ID is missing."
178 f = api.delete_release_file target_proj, target_package, target_release, target_id
179 logger.info "file #{target_id} has been deleted."