filentory-cli 0.4.0 → 0.6.2

Sign up to get free protection for your applications and to get access to all the features.
data/Gemfile.lock DELETED
@@ -1,87 +0,0 @@
1
- PATH
2
- remote: .
3
- specs:
4
- filentory-cli (0.4.0)
5
- exifr (~> 1.2.0)
6
- json_spec (~> 1.1.1)
7
- methadone (~> 1.7)
8
- oj (~> 2.11)
9
- streamio-ffmpeg (~> 1.0.0)
10
- string-scrub
11
- xmp (~> 0.2.0)
12
-
13
- GEM
14
- remote: https://rubygems.org/
15
- specs:
16
- aruba (0.6.1)
17
- childprocess (>= 0.3.6)
18
- cucumber (>= 1.1.1)
19
- rspec-expectations (>= 2.7.0)
20
- builder (3.2.2)
21
- childprocess (0.5.5)
22
- ffi (~> 1.0, >= 1.0.11)
23
- cucumber (1.3.17)
24
- builder (>= 2.1.2)
25
- diff-lcs (>= 1.1.3)
26
- gherkin (~> 2.12)
27
- multi_json (>= 1.7.5, < 2.0)
28
- multi_test (>= 0.1.1)
29
- diff-lcs (1.2.5)
30
- docile (1.1.5)
31
- exifr (1.2.0)
32
- fakeweb (1.3.0)
33
- ffi (1.9.6)
34
- gherkin (2.12.2)
35
- multi_json (~> 1.3)
36
- json (1.8.1)
37
- json_spec (1.1.4)
38
- multi_json (~> 1.0)
39
- rspec (>= 2.0, < 4.0)
40
- methadone (1.8.0)
41
- bundler
42
- minitest (5.4.3)
43
- multi_json (1.10.1)
44
- multi_test (0.1.1)
45
- nokogiri (1.5.11)
46
- oj (2.11.1)
47
- rack (1.5.2)
48
- rack-test (0.6.2)
49
- rack (>= 1.0)
50
- rake (10.3.2)
51
- rdoc (4.1.2)
52
- json (~> 1.4)
53
- rspec (3.1.0)
54
- rspec-core (~> 3.1.0)
55
- rspec-expectations (~> 3.1.0)
56
- rspec-mocks (~> 3.1.0)
57
- rspec-core (3.1.7)
58
- rspec-support (~> 3.1.0)
59
- rspec-expectations (3.1.2)
60
- diff-lcs (>= 1.2.0, < 2.0)
61
- rspec-support (~> 3.1.0)
62
- rspec-mocks (3.1.3)
63
- rspec-support (~> 3.1.0)
64
- rspec-support (3.1.2)
65
- simplecov (0.9.1)
66
- docile (~> 1.1.0)
67
- multi_json (~> 1.0)
68
- simplecov-html (~> 0.8.0)
69
- simplecov-html (0.8.0)
70
- streamio-ffmpeg (1.0.0)
71
- string-scrub (0.0.5)
72
- xmp (0.2.0)
73
- nokogiri (~> 1.5.0)
74
-
75
- PLATFORMS
76
- ruby
77
-
78
- DEPENDENCIES
79
- aruba
80
- fakeweb (~> 1.3)
81
- filentory-cli!
82
- minitest
83
- rack (~> 1.5.2)
84
- rack-test (~> 0.6.2)
85
- rake (~> 10.3)
86
- rdoc
87
- simplecov (~> 0.9.1)
data/LICENSE DELETED
@@ -1,202 +0,0 @@
1
- Apache License
2
- Version 2.0, January 2004
3
- http://www.apache.org/licenses/
4
-
5
- TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
-
7
- 1. Definitions.
8
-
9
- "License" shall mean the terms and conditions for use, reproduction,
10
- and distribution as defined by Sections 1 through 9 of this document.
11
-
12
- "Licensor" shall mean the copyright owner or entity authorized by
13
- the copyright owner that is granting the License.
14
-
15
- "Legal Entity" shall mean the union of the acting entity and all
16
- other entities that control, are controlled by, or are under common
17
- control with that entity. For the purposes of this definition,
18
- "control" means (i) the power, direct or indirect, to cause the
19
- direction or management of such entity, whether by contract or
20
- otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
- outstanding shares, or (iii) beneficial ownership of such entity.
22
-
23
- "You" (or "Your") shall mean an individual or Legal Entity
24
- exercising permissions granted by this License.
25
-
26
- "Source" form shall mean the preferred form for making modifications,
27
- including but not limited to software source code, documentation
28
- source, and configuration files.
29
-
30
- "Object" form shall mean any form resulting from mechanical
31
- transformation or translation of a Source form, including but
32
- not limited to compiled object code, generated documentation,
33
- and conversions to other media types.
34
-
35
- "Work" shall mean the work of authorship, whether in Source or
36
- Object form, made available under the License, as indicated by a
37
- copyright notice that is included in or attached to the work
38
- (an example is provided in the Appendix below).
39
-
40
- "Derivative Works" shall mean any work, whether in Source or Object
41
- form, that is based on (or derived from) the Work and for which the
42
- editorial revisions, annotations, elaborations, or other modifications
43
- represent, as a whole, an original work of authorship. For the purposes
44
- of this License, Derivative Works shall not include works that remain
45
- separable from, or merely link (or bind by name) to the interfaces of,
46
- the Work and Derivative Works thereof.
47
-
48
- "Contribution" shall mean any work of authorship, including
49
- the original version of the Work and any modifications or additions
50
- to that Work or Derivative Works thereof, that is intentionally
51
- submitted to Licensor for inclusion in the Work by the copyright owner
52
- or by an individual or Legal Entity authorized to submit on behalf of
53
- the copyright owner. For the purposes of this definition, "submitted"
54
- means any form of electronic, verbal, or written communication sent
55
- to the Licensor or its representatives, including but not limited to
56
- communication on electronic mailing lists, source code control systems,
57
- and issue tracking systems that are managed by, or on behalf of, the
58
- Licensor for the purpose of discussing and improving the Work, but
59
- excluding communication that is conspicuously marked or otherwise
60
- designated in writing by the copyright owner as "Not a Contribution."
61
-
62
- "Contributor" shall mean Licensor and any individual or Legal Entity
63
- on behalf of whom a Contribution has been received by Licensor and
64
- subsequently incorporated within the Work.
65
-
66
- 2. Grant of Copyright License. Subject to the terms and conditions of
67
- this License, each Contributor hereby grants to You a perpetual,
68
- worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69
- copyright license to reproduce, prepare Derivative Works of,
70
- publicly display, publicly perform, sublicense, and distribute the
71
- Work and such Derivative Works in Source or Object form.
72
-
73
- 3. Grant of Patent License. Subject to the terms and conditions of
74
- this License, each Contributor hereby grants to You a perpetual,
75
- worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76
- (except as stated in this section) patent license to make, have made,
77
- use, offer to sell, sell, import, and otherwise transfer the Work,
78
- where such license applies only to those patent claims licensable
79
- by such Contributor that are necessarily infringed by their
80
- Contribution(s) alone or by combination of their Contribution(s)
81
- with the Work to which such Contribution(s) was submitted. If You
82
- institute patent litigation against any entity (including a
83
- cross-claim or counterclaim in a lawsuit) alleging that the Work
84
- or a Contribution incorporated within the Work constitutes direct
85
- or contributory patent infringement, then any patent licenses
86
- granted to You under this License for that Work shall terminate
87
- as of the date such litigation is filed.
88
-
89
- 4. Redistribution. You may reproduce and distribute copies of the
90
- Work or Derivative Works thereof in any medium, with or without
91
- modifications, and in Source or Object form, provided that You
92
- meet the following conditions:
93
-
94
- (a) You must give any other recipients of the Work or
95
- Derivative Works a copy of this License; and
96
-
97
- (b) You must cause any modified files to carry prominent notices
98
- stating that You changed the files; and
99
-
100
- (c) You must retain, in the Source form of any Derivative Works
101
- that You distribute, all copyright, patent, trademark, and
102
- attribution notices from the Source form of the Work,
103
- excluding those notices that do not pertain to any part of
104
- the Derivative Works; and
105
-
106
- (d) If the Work includes a "NOTICE" text file as part of its
107
- distribution, then any Derivative Works that You distribute must
108
- include a readable copy of the attribution notices contained
109
- within such NOTICE file, excluding those notices that do not
110
- pertain to any part of the Derivative Works, in at least one
111
- of the following places: within a NOTICE text file distributed
112
- as part of the Derivative Works; within the Source form or
113
- documentation, if provided along with the Derivative Works; or,
114
- within a display generated by the Derivative Works, if and
115
- wherever such third-party notices normally appear. The contents
116
- of the NOTICE file are for informational purposes only and
117
- do not modify the License. You may add Your own attribution
118
- notices within Derivative Works that You distribute, alongside
119
- or as an addendum to the NOTICE text from the Work, provided
120
- that such additional attribution notices cannot be construed
121
- as modifying the License.
122
-
123
- You may add Your own copyright statement to Your modifications and
124
- may provide additional or different license terms and conditions
125
- for use, reproduction, or distribution of Your modifications, or
126
- for any such Derivative Works as a whole, provided Your use,
127
- reproduction, and distribution of the Work otherwise complies with
128
- the conditions stated in this License.
129
-
130
- 5. Submission of Contributions. Unless You explicitly state otherwise,
131
- any Contribution intentionally submitted for inclusion in the Work
132
- by You to the Licensor shall be under the terms and conditions of
133
- this License, without any additional terms or conditions.
134
- Notwithstanding the above, nothing herein shall supersede or modify
135
- the terms of any separate license agreement you may have executed
136
- with Licensor regarding such Contributions.
137
-
138
- 6. Trademarks. This License does not grant permission to use the trade
139
- names, trademarks, service marks, or product names of the Licensor,
140
- except as required for reasonable and customary use in describing the
141
- origin of the Work and reproducing the content of the NOTICE file.
142
-
143
- 7. Disclaimer of Warranty. Unless required by applicable law or
144
- agreed to in writing, Licensor provides the Work (and each
145
- Contributor provides its Contributions) on an "AS IS" BASIS,
146
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147
- implied, including, without limitation, any warranties or conditions
148
- of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149
- PARTICULAR PURPOSE. You are solely responsible for determining the
150
- appropriateness of using or redistributing the Work and assume any
151
- risks associated with Your exercise of permissions under this License.
152
-
153
- 8. Limitation of Liability. In no event and under no legal theory,
154
- whether in tort (including negligence), contract, or otherwise,
155
- unless required by applicable law (such as deliberate and grossly
156
- negligent acts) or agreed to in writing, shall any Contributor be
157
- liable to You for damages, including any direct, indirect, special,
158
- incidental, or consequential damages of any character arising as a
159
- result of this License or out of the use or inability to use the
160
- Work (including but not limited to damages for loss of goodwill,
161
- work stoppage, computer failure or malfunction, or any and all
162
- other commercial damages or losses), even if such Contributor
163
- has been advised of the possibility of such damages.
164
-
165
- 9. Accepting Warranty or Additional Liability. While redistributing
166
- the Work or Derivative Works thereof, You may choose to offer,
167
- and charge a fee for, acceptance of support, warranty, indemnity,
168
- or other liability obligations and/or rights consistent with this
169
- License. However, in accepting such obligations, You may act only
170
- on Your own behalf and on Your sole responsibility, not on behalf
171
- of any other Contributor, and only if You agree to indemnify,
172
- defend, and hold each Contributor harmless for any liability
173
- incurred by, or claims asserted against, such Contributor by reason
174
- of your accepting any such warranty or additional liability.
175
-
176
- END OF TERMS AND CONDITIONS
177
-
178
- APPENDIX: How to apply the Apache License to your work.
179
-
180
- To apply the Apache License to your work, attach the following
181
- boilerplate notice, with the fields enclosed by brackets "{}"
182
- replaced with your own identifying information. (Don't include
183
- the brackets!) The text should be enclosed in the appropriate
184
- comment syntax for the file format. We also recommend that a
185
- file or class name and description of purpose be included on the
186
- same "printed page" as the copyright notice for easier
187
- identification within third-party archives.
188
-
189
- Copyright {yyyy} {name of copyright owner}
190
-
191
- Licensed under the Apache License, Version 2.0 (the "License");
192
- you may not use this file except in compliance with the License.
193
- You may obtain a copy of the License at
194
-
195
- http://www.apache.org/licenses/LICENSE-2.0
196
-
197
- Unless required by applicable law or agreed to in writing, software
198
- distributed under the License is distributed on an "AS IS" BASIS,
199
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200
- See the License for the specific language governing permissions and
201
- limitations under the License.
202
-
data/README.md DELETED
@@ -1,50 +0,0 @@
1
- # Filentory-cli [![Build Status](https://travis-ci.org/jgraber/filentory-cli.png?branch=master)](https://travis-ci.org/jgraber/filentory-cli) [![Code Climate](https://codeclimate.com/github/jgraber/filentory-cli.png)](https://codeclimate.com/github/jgraber/filentory-cli) [![Gem Version](https://badge.fury.io/rb/filentory-cli.png)](http://badge.fury.io/rb/filentory-cli)
2
-
3
- A tool to create an inventory of a storage medium.
4
-
5
- ## Installation
6
-
7
- Add this line to your application's Gemfile:
8
-
9
- gem 'filentory-cli'
10
-
11
- And then execute:
12
-
13
- $ bundle
14
-
15
- Or install it yourself as:
16
-
17
- $ gem install filentory-cli
18
-
19
- ## Usage
20
-
21
- $ filentory-cli --log-level fatal "demo" .
22
- {
23
- "^o":"Datastore",
24
- "name":"demo",
25
- "files":[
26
- [
27
- {
28
- "^o":"FileEntry",
29
- "path":".",
30
- "name":"50quickideas.pdf",
31
- "last_modified":"2014-01-01T18:06:12+01:00",
32
- "size":49447,
33
- "checksum":"348a5b72877dcb5e0354f8eef62e5ff4e546043881dd051b9f8c2dea6ab23bb7"
34
- }
35
- ]
36
- }
37
-
38
-
39
- ## Contributing
40
-
41
- 1. Fork it
42
- 2. Create your feature branch (`git checkout -b my-new-feature`)
43
- 3. Commit your changes (`git commit -am 'Add some feature'`)
44
- 4. Push to the branch (`git push origin my-new-feature`)
45
- 5. Create new Pull Request
46
-
47
- ## Testing
48
- Start the minimal web service as a endpoint to send data with this command:
49
-
50
- $rackup features/support/config.ru
data/README.rdoc DELETED
@@ -1,44 +0,0 @@
1
- = filentory-cli - A tool to create an inventory of a storage medium
2
-
3
- Author:: Johnny Graber (JG@JGraber.ch)
4
- Copyright:: Copyright (c) 2014 Johnny Graber
5
-
6
- A tool to create an inventory of a storage medium.
7
-
8
- == Links
9
-
10
- * {Source on Github}[https://github.com/jgraber/filentory-cli]
11
- * RDoc[http://rdoc.info/github/jgraber/filentory-cli/frames]
12
-
13
- == Install
14
- $ gem install filentory-cli
15
-
16
- == Examples
17
- $ filentory-cli --log-level fatal "demo" .
18
- {
19
- "^o":"Datastore",
20
- "name":"demo",
21
- "files":[
22
- [
23
- {
24
- "^o":"FileEntry",
25
- "path":".",
26
- "name":"50quickideas.pdf",
27
- "last_modified":"2014-01-01T18:06:12+01:00",
28
- "size":49447,
29
- "checksum":"348a5b72877dcb5e0354f8eef62e5ff4e546043881dd051b9f8c2dea6ab23bb7"
30
- }
31
- ]
32
- }
33
-
34
- == Contributing
35
- 1. Fork it
36
- 2. Create your feature branch (`git checkout -b my-new-feature`)
37
- 3. Commit your changes (`git commit -am 'Add some feature'`)
38
- 4. Push to the branch (`git push origin my-new-feature`)
39
- 5. Create new Pull Request
40
-
41
-
42
- == Testing
43
- Start the minimal web service as a endpoint to send data with this command:
44
- $rackup features/support/config.ru
data/Rakefile DELETED
@@ -1,61 +0,0 @@
1
- def dump_load_path
2
- puts $LOAD_PATH.join("\n")
3
- found = nil
4
- $LOAD_PATH.each do |path|
5
- if File.exists?(File.join(path,"rspec"))
6
- puts "Found rspec in #{path}"
7
- if File.exists?(File.join(path,"rspec","core"))
8
- puts "Found core"
9
- if File.exists?(File.join(path,"rspec","core","rake_task"))
10
- puts "Found rake_task"
11
- found = path
12
- else
13
- puts "!! no rake_task"
14
- end
15
- else
16
- puts "!!! no core"
17
- end
18
- end
19
- end
20
- if found.nil?
21
- puts "Didn't find rspec/core/rake_task anywhere"
22
- else
23
- puts "Found in #{path}"
24
- end
25
- end
26
- require 'bundler'
27
- require 'rake/clean'
28
-
29
- require 'rake/testtask'
30
-
31
- require 'cucumber'
32
- require 'cucumber/rake/task'
33
- gem 'rdoc' # we need the installed RDoc gem, not the system one
34
- require 'rdoc/task'
35
-
36
- include Rake::DSL
37
-
38
- Bundler::GemHelper.install_tasks
39
-
40
-
41
- Rake::TestTask.new do |t|
42
- t.pattern = 'test/tc_*.rb'
43
- end
44
-
45
-
46
- CUKE_RESULTS = 'results.html'
47
- CLEAN << CUKE_RESULTS
48
- Cucumber::Rake::Task.new(:features) do |t|
49
- t.cucumber_opts = "features --format html -o #{CUKE_RESULTS} --format pretty --no-source -x"
50
- t.fork = false
51
- end
52
-
53
- Rake::RDocTask.new do |rd|
54
-
55
- rd.main = "README.rdoc"
56
-
57
- rd.rdoc_files.include("README.rdoc","lib/**/*.rb","bin/**/*")
58
- end
59
-
60
- task :default => [:test,:features]
61
-
data/bin/filentory-cli DELETED
@@ -1,77 +0,0 @@
1
- #!/usr/bin/env ruby
2
- require 'yaml'
3
- require 'optparse'
4
- require 'methadone'
5
- require 'filentory.rb'
6
- #require 'filentory/sender.rb'
7
- #require 'uri'
8
-
9
- class App
10
- include Methadone::Main
11
- include Methadone::CLILogging
12
-
13
- main do |name, path, server| # Add args you want: |like,so|
14
- absolute_path = File.expand_path(path)
15
- info("name: #{name}")
16
- info "path: #{absolute_path}"
17
- info "server: #{server}"
18
- info "mediatype: #{options[:type]}"
19
-
20
- data_store = Datastore.new (name)
21
- data_store.mediatype = options[:type]
22
- collector = Collector.new
23
- data_store.files << collector.collect(absolute_path)
24
-
25
- begin
26
- if server.nil?
27
- puts data_store.to_json
28
- else
29
-
30
- begin
31
- config_path = options[:auth] || File.join(ENV['HOME'], '.filentory.yaml')
32
- auth_data = YAML.load_file(config_path)
33
- auth_data.keys.each {|key| puts "will send #{key}"}
34
- rescue
35
- auth_data = nil
36
- end
37
-
38
- sender = Sender.new(server)
39
- sender.additional_fields = auth_data
40
- response = sender.post(data_store.to_json)
41
-
42
- if(sender.failed?)
43
- puts "ERROR: sending to '#{server}' failed: #{response.code} - #{response.message}"
44
- else
45
- puts "Sending '#{name}' to '#{server}' was successfull."
46
- end
47
- end
48
-
49
- rescue => exeption_detected
50
- puts "Error: #{exeption_detected}"
51
- end
52
- end
53
-
54
- # supplemental methods here
55
-
56
- # Declare command-line interface here
57
-
58
- description "A tool to create an filentory-cli of a storage medium"
59
-
60
- # Options:
61
- on("-t TYPE", "--type TYPE", "The type of the media to add to the filentory-cli")
62
- on("-a FILE", "--auth FILE", "A path to a YAML file with authentication information")
63
-
64
- # Arguments of Filentory-cli
65
- arg :name # required argument
66
- arg :path
67
- arg :server, :optional # optional argument
68
- #
69
- # # Make an argument optional
70
- # arg :optional_arg, :optional
71
-
72
- version Filentory::VERSION
73
-
74
- use_log_level_option
75
-
76
- go!
77
- end
@@ -1,40 +0,0 @@
1
- Feature: Filentory-cli works
2
-
3
- Scenario: App just runs
4
- When I get help for "filentory-cli"
5
- Then the exit status should be 0
6
- And the banner should be present
7
- And there should be a one line summary of what the app does
8
- And the banner should document that this app takes options
9
- And the following options should be documented:
10
- |--version|
11
- |--type|
12
- |--auth|
13
- And the banner should document that this app's arguments are:
14
- |name||
15
- |path||
16
- |server|optional|
17
-
18
- Scenario: App prints JSON
19
- When I run "filentory-cli" for the test data
20
- Then I should get JSON as output
21
- And the "name" should be "testrun"
22
- And the "mediatype" should be "DVD"
23
- And there should be 4 entries in "files"
24
- And the first file should be placed in the root folder
25
- And the second file should be in the "folder"
26
- And the image file should have metadata
27
- And the video file should have metadata
28
-
29
- Scenario: Sending data to server
30
- When I run "filentory-cli" with a server parameter
31
- Then I should get a message that the data was send successfully
32
-
33
- Scenario: YAML file present while sending data to server
34
- When I run "filentory-cli" with a server parameter and a yaml file
35
- Then I should get a message that the data was send successfully
36
- And I should get a message that "mykey" was send with the JSON data
37
-
38
- Scenario: Server does not exist
39
- When I run "filentory-cli" with the wrong server parameter
40
- Then I should get a message that the data could not be sent
@@ -1,2 +0,0 @@
1
- ---
2
- mykey: myValue
@@ -1,2 +0,0 @@
1
- require File.expand_path("../demoserver.rb", __FILE__)
2
- run DemoServer.new
@@ -1,34 +0,0 @@
1
- # -*- encoding: utf-8 -*-
2
- lib = File.expand_path('../lib', __FILE__)
3
- $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
- require 'filentory/version'
5
-
6
- Gem::Specification.new do |gem|
7
- gem.name = "filentory-cli"
8
- gem.version = Filentory::VERSION
9
- gem.authors = ["Johnny Graber"]
10
- gem.email = ["jg@jgraber.ch"]
11
- gem.description = "A tool to create an inventory of a storage medium"
12
- gem.summary = "Filentory-cli is a first step to get order in a chaotic collection of storage medias."
13
- gem.homepage = "https://github.com/jgraber/filentory-cli"
14
-
15
- gem.files = `git ls-files`.split($/)
16
- gem.executables = gem.files.grep(%r{^bin/}).map{ |f| File.basename(f) }
17
- gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
18
- gem.require_paths = ["lib"]
19
- gem.add_development_dependency('rdoc')
20
- gem.add_development_dependency('aruba')
21
- gem.add_development_dependency('rake', '~> 10.3')
22
- gem.add_development_dependency('fakeweb', '~> 1.3')
23
- gem.add_development_dependency('rack', '~>1.5.2')
24
- gem.add_development_dependency('rack-test', '~> 0.6.2')
25
- gem.add_development_dependency('minitest')
26
- gem.add_dependency('methadone', '~> 1.7')
27
- gem.add_dependency('oj', '~> 2.11')
28
- gem.add_dependency('json_spec', '~> 1.1.1')
29
- gem.add_dependency('exifr', '~> 1.2.0')
30
- gem.add_dependency('xmp', '~> 0.2.0')
31
- gem.add_dependency('streamio-ffmpeg', '~> 1.0.0')
32
- gem.add_dependency('string-scrub')
33
- gem.add_development_dependency('simplecov', '~> 0.9.1')
34
- end