fedux_org-stdlib 0.3.2 → 0.6.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.rspec +2 -0
- data/.simplecov +7 -6
- data/Gemfile +33 -28
- data/README.md +1 -1
- data/Rakefile +8 -1
- data/doc/colors.md +2 -2
- data/doc/commands.md +2 -2
- data/doc/logic_converters.md +5 -5
- data/doc/models.md +5 -5
- data/fedux_org-stdlib.gemspec +3 -7
- data/lib/fedux_org_stdlib.rb +13 -0
- data/lib/fedux_org_stdlib/app_config.rb +247 -0
- data/lib/fedux_org_stdlib/ci.rb +6 -0
- data/lib/fedux_org_stdlib/colors/html_color.rb +18 -0
- data/lib/fedux_org_stdlib/command.rb +10 -0
- data/lib/fedux_org_stdlib/command/command_result.rb +13 -0
- data/lib/fedux_org_stdlib/command/run_command.rb +55 -0
- data/lib/fedux_org_stdlib/command/which.rb +60 -0
- data/lib/fedux_org_stdlib/core_ext/array.rb +6 -0
- data/lib/fedux_org_stdlib/core_ext/string.rb +3 -0
- data/lib/fedux_org_stdlib/environment.rb +32 -0
- data/lib/fedux_org_stdlib/filesystem.rb +248 -0
- data/lib/fedux_org_stdlib/filesystem/exceptions.rb +12 -0
- data/lib/fedux_org_stdlib/logging.rb +12 -0
- data/lib/fedux_org_stdlib/logging/logger.rb +79 -0
- data/lib/{fedux_org/stdlib → fedux_org_stdlib}/logging/severity.rb +1 -0
- data/lib/fedux_org_stdlib/logic_converters.rb +11 -0
- data/lib/{fedux_org/stdlib → fedux_org_stdlib}/logic_converters/exceptions.rb +1 -0
- data/lib/fedux_org_stdlib/logic_converters/logic_converter.rb +39 -0
- data/lib/fedux_org_stdlib/logic_converters/on_off_converter.rb +35 -0
- data/lib/fedux_org_stdlib/logic_converters/true_false_converter.rb +34 -0
- data/lib/fedux_org_stdlib/logic_converters/y_n_converter.rb +34 -0
- data/lib/fedux_org_stdlib/logic_converters/yes_no_converter.rb +34 -0
- data/lib/fedux_org_stdlib/models.rb +5 -0
- data/lib/fedux_org_stdlib/models/base_model.rb +129 -0
- data/lib/fedux_org_stdlib/models/class_based_model.rb +67 -0
- data/lib/fedux_org_stdlib/models/exceptions.rb +40 -0
- data/lib/fedux_org_stdlib/models/filesystem_based_model.rb +98 -0
- data/lib/fedux_org_stdlib/project.rb +6 -0
- data/lib/fedux_org_stdlib/project/generators/taskjuggler.rb +35 -0
- data/lib/fedux_org_stdlib/project/logger.rb +12 -0
- data/lib/fedux_org_stdlib/project/plan.rb +26 -0
- data/lib/fedux_org_stdlib/project/report.rb +63 -0
- data/lib/fedux_org_stdlib/rake.rb +8 -0
- data/lib/fedux_org_stdlib/rake/exceptions.rb +9 -0
- data/lib/{fedux_org/stdlib → fedux_org_stdlib}/rake/project.rb +4 -4
- data/lib/fedux_org_stdlib/rake/project_task.rb +29 -0
- data/lib/fedux_org_stdlib/rake/shell_task.rb +45 -0
- data/lib/fedux_org_stdlib/rake/sub_task.rb +26 -0
- data/lib/fedux_org_stdlib/rake/task.rb +118 -0
- data/lib/fedux_org_stdlib/rake/version_bump_task.rb +56 -0
- data/lib/fedux_org_stdlib/rake_tasks.rb +8 -0
- data/lib/fedux_org_stdlib/rake_tasks/console.rb +11 -0
- data/lib/fedux_org_stdlib/rake_tasks/documentation.rb +2 -0
- data/lib/fedux_org_stdlib/rake_tasks/documentation/yard.rb +9 -0
- data/lib/fedux_org_stdlib/rake_tasks/gems.rb +3 -0
- data/lib/fedux_org_stdlib/rake_tasks/gems/bundler.rb +9 -0
- data/lib/fedux_org_stdlib/rake_tasks/gems/package.rb +9 -0
- data/lib/fedux_org_stdlib/rake_tasks/project.rb +1 -0
- data/lib/fedux_org_stdlib/rake_tasks/project/report.rb +3 -0
- data/lib/fedux_org_stdlib/rake_tasks/project/report/generate.rb +10 -0
- data/lib/fedux_org_stdlib/rake_tasks/project/report/open.rb +12 -0
- data/lib/fedux_org_stdlib/rake_tasks/project/report/open_shortcut.rb +9 -0
- data/lib/fedux_org_stdlib/rake_tasks/qa.rb +4 -0
- data/lib/fedux_org_stdlib/rake_tasks/qa/rubocop.rb +13 -0
- data/lib/fedux_org_stdlib/rake_tasks/qa/travis.rb +13 -0
- data/lib/fedux_org_stdlib/rake_tasks/terminal.rb +9 -0
- data/lib/fedux_org_stdlib/rake_tasks/tests.rb +4 -0
- data/lib/fedux_org_stdlib/rake_tasks/tests/cucumber.rb +13 -0
- data/lib/fedux_org_stdlib/rake_tasks/tests/rspec.rb +12 -0
- data/lib/fedux_org_stdlib/rake_tasks/tests/travis.rb +11 -0
- data/lib/fedux_org_stdlib/rake_tasks/version.rb +6 -0
- data/lib/fedux_org_stdlib/rake_tasks/version/bump.rb +8 -0
- data/lib/fedux_org_stdlib/rake_tasks/version/restore.rb +11 -0
- data/lib/fedux_org_stdlib/rake_tasks/version/show.rb +12 -0
- data/lib/fedux_org_stdlib/rake_tasks/version/show_shortcut.rb +9 -0
- data/lib/fedux_org_stdlib/require_files.rb +27 -0
- data/lib/fedux_org_stdlib/version.rb +5 -0
- data/lib/fedux_org_stdlib/version_management/exceptions.rb +9 -0
- data/lib/fedux_org_stdlib/version_management/library_builder.rb +12 -0
- data/lib/fedux_org_stdlib/version_management/ruby_library.rb +13 -0
- data/lib/fedux_org_stdlib/version_management/rubygem_version_file.rb +78 -0
- data/lib/fedux_org_stdlib/version_management/rubygem_version_file_parser.rb +22 -0
- data/lib/fedux_org_stdlib/version_management/version.rb +25 -0
- data/lib/fedux_org_stdlib/version_management/version_builder.rb +12 -0
- data/lib/fedux_org_stdlib/versionable.rb +18 -0
- data/rakefiles/default.rake +8 -1
- data/rakefiles/travis.rake +1 -1
- data/script/console +1 -1
- data/script/terminal +3 -2
- data/spec/app_config_spec.rb +7 -0
- data/spec/colors/html_color_spec.rb +7 -14
- data/spec/command/run_command_spec.rb +9 -10
- data/spec/command/which_spec.rb +8 -9
- data/spec/environment_spec.rb +12 -11
- data/spec/logger/logger_spec.rb +17 -16
- data/spec/logic_converters/on_off_converter_spec.rb +8 -7
- data/spec/logic_converters/true_false_converter_spec.rb +8 -7
- data/spec/logic_converters/y_n_converter_spec.rb +8 -7
- data/spec/logic_converters/yes_no_converter_spec.rb +8 -7
- data/spec/models/base_model_spec.rb +7 -7
- data/spec/models/class_based_model_spec.rb +37 -39
- data/spec/models/filesystem_based_model_spec.rb +24 -24
- data/spec/project/plan_spec.rb +6 -5
- data/spec/project/report_spec.rb +35 -29
- data/spec/project/taskjuggler_spec.rb +13 -12
- data/spec/spec_helper.rb +15 -38
- data/spec/support/environment.rb +16 -0
- data/spec/support/filesystem.rb +19 -0
- data/spec/support/reporting.rb +2 -0
- data/spec/support/rspec.rb +5 -0
- data/spec/support/string.rb +2 -0
- data/spec/version_management/library_builder_spec.rb +5 -4
- data/spec/version_management/ruby_library_spec.rb +5 -4
- data/spec/version_management/rubygem_version_file_parser_spec.rb +27 -16
- data/spec/version_management/rubygem_version_file_spec.rb +56 -54
- data/spec/version_management/version_builder_spec.rb +5 -4
- data/spec/version_management/version_spec.rb +16 -16
- metadata +104 -110
- data/lib/fedux_org/stdlib.rb +0 -15
- data/lib/fedux_org/stdlib/colors/html_color.rb +0 -19
- data/lib/fedux_org/stdlib/command.rb +0 -11
- data/lib/fedux_org/stdlib/command/command_result.rb +0 -14
- data/lib/fedux_org/stdlib/command/run_command.rb +0 -55
- data/lib/fedux_org/stdlib/command/which.rb +0 -67
- data/lib/fedux_org/stdlib/environment.rb +0 -31
- data/lib/fedux_org/stdlib/filesystem.rb +0 -247
- data/lib/fedux_org/stdlib/filesystem/exceptions.rb +0 -13
- data/lib/fedux_org/stdlib/logging.rb +0 -13
- data/lib/fedux_org/stdlib/logging/logger.rb +0 -79
- data/lib/fedux_org/stdlib/logic_converters.rb +0 -12
- data/lib/fedux_org/stdlib/logic_converters/logic_converter.rb +0 -40
- data/lib/fedux_org/stdlib/logic_converters/on_off_converter.rb +0 -36
- data/lib/fedux_org/stdlib/logic_converters/true_false_converter.rb +0 -35
- data/lib/fedux_org/stdlib/logic_converters/y_n_converter.rb +0 -35
- data/lib/fedux_org/stdlib/logic_converters/yes_no_converter.rb +0 -35
- data/lib/fedux_org/stdlib/models.rb +0 -4
- data/lib/fedux_org/stdlib/models/base_model.rb +0 -129
- data/lib/fedux_org/stdlib/models/class_based_model.rb +0 -76
- data/lib/fedux_org/stdlib/models/exceptions.rb +0 -41
- data/lib/fedux_org/stdlib/models/filesystem_based_model.rb +0 -99
- data/lib/fedux_org/stdlib/project.rb +0 -5
- data/lib/fedux_org/stdlib/project/generators/taskjuggler.rb +0 -41
- data/lib/fedux_org/stdlib/project/logger.rb +0 -13
- data/lib/fedux_org/stdlib/project/plan.rb +0 -15
- data/lib/fedux_org/stdlib/project/report.rb +0 -67
- data/lib/fedux_org/stdlib/rake.rb +0 -7
- data/lib/fedux_org/stdlib/rake/console.rb +0 -3
- data/lib/fedux_org/stdlib/rake/documentation.rb +0 -1
- data/lib/fedux_org/stdlib/rake/documentation/yard.rb +0 -14
- data/lib/fedux_org/stdlib/rake/gems.rb +0 -2
- data/lib/fedux_org/stdlib/rake/gems/bundler.rb +0 -12
- data/lib/fedux_org/stdlib/rake/gems/package.rb +0 -7
- data/lib/fedux_org/stdlib/rake/library.rb +0 -8
- data/lib/fedux_org/stdlib/rake/terminal.rb +0 -9
- data/lib/fedux_org/stdlib/rake/tests.rb +0 -3
- data/lib/fedux_org/stdlib/rake/tests/cucumber.rb +0 -6
- data/lib/fedux_org/stdlib/rake/tests/rspec.rb +0 -6
- data/lib/fedux_org/stdlib/rake/tests/travis.rb +0 -15
- data/lib/fedux_org/stdlib/rake/travis.rb +0 -1
- data/lib/fedux_org/stdlib/rake/travis/lint.rb +0 -10
- data/lib/fedux_org/stdlib/rake/version.rb +0 -4
- data/lib/fedux_org/stdlib/rake/version/base.rb +0 -7
- data/lib/fedux_org/stdlib/rake/version/bump.rb +0 -78
- data/lib/fedux_org/stdlib/rake/version/restore.rb +0 -9
- data/lib/fedux_org/stdlib/rake/version/show.rb +0 -9
- data/lib/fedux_org/stdlib/rake/version/show_shortcut.rb +0 -6
- data/lib/fedux_org/stdlib/version.rb +0 -6
- data/lib/fedux_org/stdlib/version_management/library_builder.rb +0 -15
- data/lib/fedux_org/stdlib/version_management/ruby_library.rb +0 -14
- data/lib/fedux_org/stdlib/version_management/rubygem_version_file.rb +0 -90
- data/lib/fedux_org/stdlib/version_management/rubygem_version_file_parser.rb +0 -18
- data/lib/fedux_org/stdlib/version_management/version.rb +0 -33
- data/lib/fedux_org/stdlib/version_management/version_builder.rb +0 -15
@@ -0,0 +1,18 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
module FeduxOrgStdlib
|
3
|
+
module Colors
|
4
|
+
class HtmlColor
|
5
|
+
# @param [String] color
|
6
|
+
# string in the html color format
|
7
|
+
def initialize( color )
|
8
|
+
@color = color
|
9
|
+
@validator_regex = /^#[a-f0-9]{6}$/
|
10
|
+
end
|
11
|
+
|
12
|
+
# @return [true,false] color string is valid
|
13
|
+
def valid?
|
14
|
+
@validator_regex === @color
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
require 'fedux_org_stdlib/require_files'
|
3
|
+
require_library %w{ open3 }
|
4
|
+
|
5
|
+
require 'fedux_org_stdlib/environment'
|
6
|
+
require 'fedux_org_stdlib/command/command_result'
|
7
|
+
|
8
|
+
module FeduxOrgStdlib
|
9
|
+
module Command
|
10
|
+
module RunCommand
|
11
|
+
include Environment
|
12
|
+
|
13
|
+
# Execute command
|
14
|
+
#
|
15
|
+
# @param [String] cmd
|
16
|
+
# the command
|
17
|
+
#
|
18
|
+
# @param [Hash] options
|
19
|
+
# the options for command execution
|
20
|
+
#
|
21
|
+
# @option options [Hash] env ({])
|
22
|
+
# the environment variables for the command ('VAR' => 'CONTENT')
|
23
|
+
#
|
24
|
+
# @option options [String] stdin (nil)
|
25
|
+
# the string for stdin of the command
|
26
|
+
#
|
27
|
+
# @option options [TrueClass,FalseClass] binmode (false)
|
28
|
+
# should the stdin be read a binary or not
|
29
|
+
#
|
30
|
+
# @return [CommandResult]
|
31
|
+
# the result of the command execution
|
32
|
+
#
|
33
|
+
# @return [CommandResult]
|
34
|
+
# the result of the command execution
|
35
|
+
def run_command(cmd,options={})
|
36
|
+
opts = {
|
37
|
+
env: nil,
|
38
|
+
stdin: nil,
|
39
|
+
binmode: false,
|
40
|
+
working_directory: Dir.getwd,
|
41
|
+
}.merge options
|
42
|
+
|
43
|
+
env = opts[:env] || ENV.to_hash
|
44
|
+
stdin = opts[:stdin]
|
45
|
+
binmode = opts[:binmode]
|
46
|
+
working_directory = opts[:working_directory]
|
47
|
+
|
48
|
+
result = CommandResult.new
|
49
|
+
result.stdout, result.stderr, result.status = Open3.capture3(env, cmd, stdin_data: stdin, chdir: working_directory, binmode: binmode)
|
50
|
+
|
51
|
+
result
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,60 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
require 'fedux_org_stdlib/require_files'
|
3
|
+
require_library %w{ pathname active_support/core_ext/object/blank }
|
4
|
+
|
5
|
+
module FeduxOrgStdlib
|
6
|
+
module Command
|
7
|
+
module Which
|
8
|
+
|
9
|
+
# Search for command
|
10
|
+
# @param [String] cmd
|
11
|
+
# name of command or path to command (will be reduced to basename and then searched in PATH)
|
12
|
+
#
|
13
|
+
# @param [Array,String] paths
|
14
|
+
# a string containing paths separated by "File::PATH_SEPARATOR" or an array of paths
|
15
|
+
#
|
16
|
+
# @param [Array,String] pathexts
|
17
|
+
# a string containing pathexts separated by ";" or an array of pathexts
|
18
|
+
#
|
19
|
+
# @return [String]
|
20
|
+
# path to command
|
21
|
+
def which(cmd, options={})
|
22
|
+
options = {
|
23
|
+
paths: ENV['PATH'].split(File::PATH_SEPARATOR),
|
24
|
+
pathexts: ENV['PATHEXT'].to_s.split( /;/ ),
|
25
|
+
raise_error_on_not_executable: false,
|
26
|
+
raise_error_on_not_found: false,
|
27
|
+
}.merge options
|
28
|
+
|
29
|
+
cmd = Pathname.new(cmd)
|
30
|
+
|
31
|
+
paths = options[:paths]
|
32
|
+
pathexts = options[:pathexts]
|
33
|
+
raise_error_on_not_executable = options[:raise_error_on_not_executable]
|
34
|
+
raise_error_on_not_found = options[:raise_error_on_not_found]
|
35
|
+
|
36
|
+
raise Exceptions::CommandNotFound if cmd.to_s.empty?
|
37
|
+
return nil if cmd.to_s.empty?
|
38
|
+
|
39
|
+
if cmd.absolute?
|
40
|
+
return cmd.to_s if cmd.executable?
|
41
|
+
raise Exceptions::CommandNotFound if raise_error_on_not_found and not cmd.exist?
|
42
|
+
raise Exceptions::CommandNotExecutable if raise_error_on_not_executable and not cmd.executable?
|
43
|
+
return nil
|
44
|
+
end
|
45
|
+
|
46
|
+
pathexts = [''] if pathexts.blank?
|
47
|
+
|
48
|
+
Array( paths ).each do |path|
|
49
|
+
Array( pathexts ).each do |ext|
|
50
|
+
file = Pathname.new( File.join(path, "#{cmd.to_s}#{ext.to_s}") )
|
51
|
+
return file.to_s if file.executable?
|
52
|
+
raise Exceptions::CommandNotExecutable if raise_error_on_not_executable and not cmd.executable?
|
53
|
+
end
|
54
|
+
end
|
55
|
+
raise Exceptions::CommandNotFound if raise_error_on_not_found
|
56
|
+
nil
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
module FeduxOrgStdlib
|
3
|
+
module Environment
|
4
|
+
|
5
|
+
# Set environment variable for code block
|
6
|
+
#
|
7
|
+
# @param [Hash] new_environment_variables
|
8
|
+
# the variables which should be set for that environment
|
9
|
+
#
|
10
|
+
# @param [Hash] options
|
11
|
+
# options for environment manipulation
|
12
|
+
#
|
13
|
+
# @option options [True,False] :clear
|
14
|
+
# Should the environment clear before merge?
|
15
|
+
#
|
16
|
+
# @yield
|
17
|
+
# the block which should be run which the change environment
|
18
|
+
def isolated_environment(new_environment_variables, options={}, &block)
|
19
|
+
old_environment = ENV.to_hash
|
20
|
+
|
21
|
+
ENV.clear if options[:clear] == true
|
22
|
+
ENV.update new_environment_variables
|
23
|
+
|
24
|
+
block.call
|
25
|
+
ensure
|
26
|
+
ENV.clear
|
27
|
+
ENV.update old_environment
|
28
|
+
end
|
29
|
+
|
30
|
+
alias_method :with_environment, :isolated_environment
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,248 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
require 'fedux_org_stdlib/require_files'
|
3
|
+
require_library %w{ fileutils }
|
4
|
+
|
5
|
+
require 'fedux_org_stdlib/filesystem/exceptions'
|
6
|
+
|
7
|
+
# helper for file system
|
8
|
+
module FeduxOrgStdlib
|
9
|
+
module Filesystem
|
10
|
+
|
11
|
+
# The root directory of the project
|
12
|
+
#
|
13
|
+
# @return [String]
|
14
|
+
# the root directory
|
15
|
+
def root_directory
|
16
|
+
#::File.expand_path('../../../', __FILE__)
|
17
|
+
raise Exceptions::InvalidUsageOfLibrary , "Sorry, but you need to define the root directory yourself"
|
18
|
+
end
|
19
|
+
|
20
|
+
# The temporary directory for the project
|
21
|
+
#
|
22
|
+
# @return [String]
|
23
|
+
# the directory created for the tests
|
24
|
+
def working_directory
|
25
|
+
::File.join(root_directory, 'tmp', 'test')
|
26
|
+
end
|
27
|
+
|
28
|
+
# Create temporary directory
|
29
|
+
def create_working_directory
|
30
|
+
FileUtils.mkdir_p(working_directory) unless ::File.exists? working_directory
|
31
|
+
end
|
32
|
+
|
33
|
+
# Delete temporary directory
|
34
|
+
def delete_working_directory
|
35
|
+
FileUtils.rm_rf(working_directory) if ::File.exists? working_directory
|
36
|
+
end
|
37
|
+
|
38
|
+
# Clean up test directory
|
39
|
+
def cleanup_working_directory
|
40
|
+
delete_working_directory
|
41
|
+
create_working_directory
|
42
|
+
end
|
43
|
+
|
44
|
+
# Switch the current working directory to
|
45
|
+
# the temporary one and execute code block
|
46
|
+
def switch_to_working_directory(&block)
|
47
|
+
Dir.chdir(working_directory, &block)
|
48
|
+
end
|
49
|
+
alias_method :in_working_directory, :switch_to_working_directory
|
50
|
+
|
51
|
+
# Create directory(ies)
|
52
|
+
#
|
53
|
+
# @param [String,Array] dirs
|
54
|
+
# the directories to be created, multiple arguments are possible as well
|
55
|
+
#
|
56
|
+
# @return [String,Array]
|
57
|
+
# returns a string if there was only one file given, and an array with
|
58
|
+
# muliple files
|
59
|
+
def create_directory(*dirs)
|
60
|
+
raise_if_forbidden_path_for_create_operation(dirs)
|
61
|
+
|
62
|
+
directories = expand_path(dirs.flatten)
|
63
|
+
FileUtils.mkdir_p(directories)
|
64
|
+
|
65
|
+
if directories.size == 1
|
66
|
+
return directories.first
|
67
|
+
else
|
68
|
+
return directories
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
# Delete directory(ies)
|
73
|
+
#
|
74
|
+
# @param [String, Array] dirs
|
75
|
+
# the directories to be deleted, multiple arguments are possible as well
|
76
|
+
#
|
77
|
+
# @return [String,Array]
|
78
|
+
# returns a string if there was only one file given, and an array with
|
79
|
+
# muliple files
|
80
|
+
def delete_directory(*dirs)
|
81
|
+
raise_if_forbidden_path_for_delete_operation(dirs)
|
82
|
+
|
83
|
+
directories = expand_path(dirs.flatten)
|
84
|
+
FileUtils.rm_r(directories)
|
85
|
+
|
86
|
+
if directories.size == 1
|
87
|
+
return directories.first
|
88
|
+
else
|
89
|
+
return directories
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
# Check existence of path(s)
|
94
|
+
#
|
95
|
+
# @param [String,Array] paths
|
96
|
+
# which path(s) should be checked, multiple arguments are possible as well
|
97
|
+
#
|
98
|
+
# @return [TrueClass,FalseClass]
|
99
|
+
# the result of all checks done
|
100
|
+
def path_exists?(*paths)
|
101
|
+
raise_if_forbidden_path_for_create_operation(paths)
|
102
|
+
|
103
|
+
paths_expanded = expand_path(paths.flatten)
|
104
|
+
paths_expanded.flatten.all? { |p| ::File.exists?(p) }
|
105
|
+
end
|
106
|
+
|
107
|
+
# Check absence of path(s)
|
108
|
+
#
|
109
|
+
# @param [String,Array] paths
|
110
|
+
# which path(s) should be checked, multiple arguments are possible as well
|
111
|
+
#
|
112
|
+
# @return [TrueClass,FalseClass]
|
113
|
+
# the result of all checks done
|
114
|
+
def path_does_not_exist?(*paths)
|
115
|
+
not path_exists?(paths)
|
116
|
+
end
|
117
|
+
|
118
|
+
# Create a single file
|
119
|
+
#
|
120
|
+
# @param [String] path
|
121
|
+
# the path for the new file (can include directories)
|
122
|
+
#
|
123
|
+
# @param [String] content
|
124
|
+
# the content written to the file
|
125
|
+
#
|
126
|
+
# @return [String]
|
127
|
+
# the path to the created file
|
128
|
+
def create_file(path, content='', mode=0644)
|
129
|
+
raise_if_forbidden_path_for_create_operation(path)
|
130
|
+
|
131
|
+
file = expand_path(path).first
|
132
|
+
directory = ::File.dirname(file)
|
133
|
+
|
134
|
+
FileUtils.mkdir_p(directory) unless directory == '.'
|
135
|
+
::File.open(file, "wb") do |f|
|
136
|
+
f.write content
|
137
|
+
end
|
138
|
+
|
139
|
+
FileUtils.chmod(mode, file)
|
140
|
+
|
141
|
+
file
|
142
|
+
end
|
143
|
+
|
144
|
+
# Delete a single file
|
145
|
+
#
|
146
|
+
# @param [String] files
|
147
|
+
# the path for the new file (can include directories)
|
148
|
+
#
|
149
|
+
# @return [String]
|
150
|
+
# the path to the deleted file
|
151
|
+
def delete_file(*files)
|
152
|
+
raise_if_forbidden_path_for_delete_operation(files)
|
153
|
+
|
154
|
+
files_to_be_deleted = expand_path(files.flatten)
|
155
|
+
FileUtils.rm(files_to_be_deleted)
|
156
|
+
|
157
|
+
if files_to_be_deleted.size == 1
|
158
|
+
return files_to_be_deleted.first
|
159
|
+
else
|
160
|
+
return files_to_be_deleted
|
161
|
+
end
|
162
|
+
end
|
163
|
+
|
164
|
+
# Read the content of a file
|
165
|
+
#
|
166
|
+
# @param [String] path
|
167
|
+
# the path to the file
|
168
|
+
#
|
169
|
+
# @return [String,Binary]
|
170
|
+
# the content of the file
|
171
|
+
def read_file(path)
|
172
|
+
raise_if_forbidden_path_for_create_operation(path)
|
173
|
+
|
174
|
+
file_path = expand_path(path).first
|
175
|
+
return ::File.read(file_path)
|
176
|
+
end
|
177
|
+
|
178
|
+
# Expand path based on temporary directory
|
179
|
+
#
|
180
|
+
# @param [String, Array, Multiple Values] paths
|
181
|
+
# the paths to be expanded
|
182
|
+
#
|
183
|
+
# @return [Array, String]
|
184
|
+
# the expanded arrays
|
185
|
+
def expand_path(*paths)
|
186
|
+
raise_if_forbidden_path_for_create_operation(paths)
|
187
|
+
|
188
|
+
paths.flatten.map do |p|
|
189
|
+
case p
|
190
|
+
when /^~/
|
191
|
+
::File.expand_path(p)
|
192
|
+
else
|
193
|
+
::File.join(working_directory, p )
|
194
|
+
end
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
198
|
+
# Check if path is forbidden for delete operation
|
199
|
+
#
|
200
|
+
# @param [String, Array] paths
|
201
|
+
# paths which should be checked
|
202
|
+
#
|
203
|
+
# @return [TrueClass, FalseClass]
|
204
|
+
# true if path is forbidden, false if path is not forbidden
|
205
|
+
def raise_if_forbidden_path_for_create_operation(*paths)
|
206
|
+
flattend_paths = paths.flatten
|
207
|
+
strings = []
|
208
|
+
regex = %r[\.\.]
|
209
|
+
|
210
|
+
raise FileSystem::Exceptions::InvalidPath , "Sorry, but you cannot use paths matching \"#{strings.join(', ')}\" or \"#{regex.inspect}\" here!" if path_matches?(strings, regex, flattend_paths)
|
211
|
+
end
|
212
|
+
|
213
|
+
# Check if path is forbidden for delete operation
|
214
|
+
#
|
215
|
+
# @param [String, Array] paths
|
216
|
+
# paths which should be checked
|
217
|
+
#
|
218
|
+
# @return [TrueClass, FalseClass]
|
219
|
+
# true if path is forbidden, false if path is not forbidden
|
220
|
+
def raise_if_forbidden_path_for_delete_operation(*paths)
|
221
|
+
flattend_paths = paths.flatten
|
222
|
+
strings = %w[ / ]
|
223
|
+
regex = %r[\.\.]
|
224
|
+
|
225
|
+
raise FileSystem::Exceptions::InvalidPath , "Sorry, but you cannot use paths matching \"#{strings.join(', ')}\" or \"#{regex.to_s}\" here!" if path_matches?(strings, regex, flattend_paths)
|
226
|
+
end
|
227
|
+
|
228
|
+
# Check if path matches
|
229
|
+
#
|
230
|
+
# @param [Array, String] strings
|
231
|
+
# strings which are checked against paths
|
232
|
+
#
|
233
|
+
# @param [Array, String] regex
|
234
|
+
# regex which is checked against path
|
235
|
+
#
|
236
|
+
# @param [Array, String] paths
|
237
|
+
# the paths to be checked
|
238
|
+
#
|
239
|
+
# @return [TrueClass, FalseClass]
|
240
|
+
# true if path is valid, false if invalid
|
241
|
+
def path_matches?(strings, regex, *paths)
|
242
|
+
flattend_paths = paths.flatten
|
243
|
+
flattend_strings = strings.flatten
|
244
|
+
|
245
|
+
flattend_paths.any? { |f| f =~ regex or flattend_strings.include?(f) }
|
246
|
+
end
|
247
|
+
end
|
248
|
+
end
|