1 module OSDN; module CLI; module Command
4 puts "#{$0} frs_upload [opts] [target_dir]"
6 puts " -n --dry-run Do noting (use with global -v to inspect)"
7 puts " -p --project=<project> Target project (numeric id or name)"
8 #puts " --package=<project> Target package (numeric id)"
9 #puts " --release=<project> Target release (numeric id)"
10 puts " -v --visibility=<public|private|hidden>"
11 puts " Default visibility for newly created items"
12 puts " --force-digest Calc local file digest forcely"
17 opts = GetoptLong.new(
18 [ '--dry-run', '-n', GetoptLong::NO_ARGUMENT ],
19 [ '--project', '-p', GetoptLong::REQUIRED_ARGUMENT ],
20 [ '--release', '-r', GetoptLong::REQUIRED_ARGUMENT ],
21 [ '--visibility', '-v', GetoptLong::REQUIRED_ARGUMENT ],
22 [ '--force-digest', GetoptLong::NO_ARGUMENT],
24 opts.each do |opt, arg|
31 # @target_release = arg
34 # @target_package = arg
36 unless %w(public private hidden).member?(arg)
37 logger.fatal "Invalid visibility status: #{arg}"
48 @target_dir = Pathname.new(ARGV.shift || '.')
49 proj_info = api.get_project target_proj # check project existance
51 Pathname.glob(@target_dir+'*').sort.each do |pdir|
52 unless load_variables(pdir).package_id
53 logger.info "Createing new package '#{pdir.basename}'"
55 pinfo = Hashie::Mash.new id: '(dry-run)', name: pdir.basename, url: '(dry-run)'
57 pinfo = api.create_package target_proj, pdir.basename, visibility: @visibility
58 update_variables pdir, package_id: pinfo.id
60 $stdout.puts "New package '#{pinfo.name}' has been created; #{pinfo.url}"
63 Pathname.glob(pdir + '*').sort.each do |rdir|
65 logger.warn "Skip normal file '#{rdir}' in release level"
69 vars = load_variables(rdir)
72 rinfo = api.get_release target_proj, target_package(rdir), target_release(rdir)
74 logger.info "Createing new release '#{rdir.basename}'"
76 rinfo = Hashie::Mash.new id: '(dry-run)', name: rdir.basename, url: '(dry-run)', files: []
78 rinfo = api.create_release target_proj, target_package(rdir), rdir.basename, visibility: @visibility
79 update_variables rdir, release_id: rinfo.id
81 $stdout.puts "New release '#{rinfo.name}' has been created; #{rinfo.url}"
84 Pathname.glob(rdir + '*').sort.each do |file|
86 logger.error "Skip direcotry #{file}"
90 vars = load_variables(rdir)
92 if !@force_digest && vars.local_file_info &&
93 vars.local_file_info[file.basename.to_s]
94 finfo = vars.local_file_info[file.basename.to_s]
95 if finfo[:size] == file.size && finfo.mtime == file.mtime
96 digests = vars.local_file_info[file.basename.to_s].digests
101 logger.info "Calculating digest for #{file}..."
103 sha256: hexdigest(Digest::SHA256, file),
104 sha1: hexdigest(Digest::SHA1, file),
105 md5: hexdigest(Digest::MD5, file),
107 update_variables rdir, {local_file_info: {file.basename.to_s => {digests: digests, mtime: file.mtime, size: file.size}}}
109 if remote_f = rinfo.files.find { |f| f.name == file.basename.to_s }
110 if digests.find { |type, dig| dig != remote_f.send("digest_#{type}") }
111 logger.error "#{file} was changed from remote file! Please delete remote file before uploading new one."
113 logger.info "Skip already uploaded file '#{file}'"
115 logger.info "Uploading file #{file} (#{file.size} bytes)"
117 finfo = Hashie::Mash.new id: '(dry-run)', url: '(dry-run)'
119 logger.level <= Logger::INFO and
120 OSDN::CLI._show_progress = true
122 logger.info "Starting upload #{file}..."
123 finfo = api.create_release_file target_proj, target_package(rdir), target_release(rdir), fio, visibility: @visibility
125 OSDN::CLI._show_progress = false
126 if digests.find { |type, dig| dig != finfo.send("digest_#{type}") }
127 logger.error "File digests are mismatch! Upload file #{file} may be broken! Please check."
129 logger.info "Upload complete."
132 $stdout.puts "New file '#{file}' has been uploaded; #{finfo.url}"
140 "Upload local file tree and create package/release implicitly."
145 @target_proj and return @target_proj
146 vars = load_variables(@target_dir)
147 vars.project && !vars.project.empty? and
149 logger.fatal "No target project is specified."
153 def target_package(dir)
154 @target_package and return @target_package
155 vars = load_variables(dir)
156 vars.package_id && !vars.package_id.to_s.empty? and
157 return vars.package_id
158 logger.fatal "No target package is specified."
162 def target_release(dir)
163 @target_release and return @target_release
164 vars = load_variables(dir)
165 vars.release_id && !vars.release_id.to_s.empty? and
166 return vars.release_id
167 logger.fatal "No target release is specified."
172 OSDNClient::ProjectApi.new