Module: Aspera::Cli::SyncActions
- Included in:
- Plugins::Config, Plugins::Node, Plugins::Server
- Defined in:
- lib/aspera/cli/sync_actions.rb
Overview
Manage command line arguments to provide to Sync::Operations and Sync::Database
Constant Summary collapse
- STATE_STR =
Translate state id (int) to string
(['Nil'] + (1..18).map{ |i| "P(#{i})"} + %w[Syncd Error Confl Pconf] + (23..24).map{ |i| "P(#{i})"}).freeze
Class Method Summary collapse
Instance Method Summary collapse
-
#async_info_from_args(direction: nil) ⇒ Hash
Read 1 or 2 command line arguments and converts to
sync_infoformat The resulting sync_info hasargsformat only if it contains one of thesessionsorinstancekeys. -
#db_from_args ⇒ Object
Provide database object from command line arguments for admin ops.
-
#execute_sync_action(&block) ⇒ Object
Execute sync action.
- #execute_sync_admin ⇒ Object
Class Method Details
.declare_options(_options) ⇒ Object
18 19 |
# File 'lib/aspera/cli/sync_actions.rb', line 18 def () end |
Instance Method Details
#async_info_from_args(direction: nil) ⇒ Hash
Read 1 or 2 command line arguments and converts to sync_info format The resulting sync_info has args format only if it contains one of the sessions or instance keys. It has the conf format (default) otherwise. If the conf format is detected, then both local and remote keys are set.
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/aspera/cli/sync_actions.rb', line 28 def async_info_from_args(direction: nil) path = .get_next_argument('path') sync_info = .get_next_argument('sync info', mandatory: false, validation: Hash, default: {}) # is the positional path a remote path ? path_is_remote = direction.eql?(:pull) if sync_info.key?('sessions') || sync_info.key?('instance') # `args` sync_info['sessions'] ||= [{}] Aspera.assert(sync_info['sessions'].length == 1){'Only one session is supported'} session = sync_info['sessions'].first dir_key = path_is_remote ? 'remote_dir' : 'local_dir' raise "Parameter #{dir_key} shall not be in sync_info" if session.key?(dir_key) session[dir_key] = path if direction dir_key = path_is_remote ? 'local_dir' : 'remote_dir' raise "Parameter #{dir_key} shall not be in sync_info" if session.key?(dir_key) session[dir_key] = transfer.destination_folder(path_is_remote ? Transfer::Spec::DIRECTION_RECEIVE : Transfer::Spec::DIRECTION_SEND) local_remote = %w[local remote].map{ |i| session["#{i}_dir"]} end else # `conf` session = sync_info dir_key = path_is_remote ? 'remote' : 'local' session[dir_key] ||= {} raise "Parameter #{dir_key}.path shall not be in sync_info" if session[dir_key].key?('path') session[dir_key]['path'] = path if direction dir_key = path_is_remote ? 'local' : 'remote' session[dir_key] ||= {} raise "Parameter #{dir_key}.path shall not be in sync_info" if session[dir_key].key?('path') session[dir_key]['path'] = transfer.destination_folder(path_is_remote ? Transfer::Spec::DIRECTION_RECEIVE : Transfer::Spec::DIRECTION_SEND) local_remote = %w[local remote].map{ |i| session[i]['path']} end # `conf` is quiet by default session['quiet'] = false if !session.key?('quiet') && Environment.terminal? end if direction raise BadArgument, 'direction shall not be in sync_info' if session.key?('direction') session['direction'] = direction.to_s # generate name if not provided by user if !session.key?('name') safe_char = Environment.instance.safe_filename_character # from async man page: # -N : can contain only ASCII alphanumeric, hyphen, and underscore characters session['name'] = Environment.instance.sanitized_filename( ([direction.to_s] + local_remote).map do |value| Pathname(value).each_filename.to_a.last(2).join(safe_char) end.join(safe_char).gsub(/[^A-Za-z0-9_-]/, safe_char) ) end end sync_info end |
#db_from_args ⇒ Object
Provide database object from command line arguments for admin ops
83 84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/aspera/cli/sync_actions.rb', line 83 def db_from_args sync_info = async_info_from_args session = sync_info.key?('sessions') ? sync_info['sessions'].first : sync_info # if name not provided, check in db folder if there is only one name if !session.key?('name') local_db_dir = Sync::Operations.local_db_folder(sync_info) dbs = Sync::Operations.list_db_files(local_db_dir) raise "#{dbs.length} session found in #{local_db_dir}, please provide a name" unless dbs.length == 1 session['name'] = dbs.keys.first end Sync::Database.new(Sync::Operations.session_db_file(sync_info)) end |
#execute_sync_action(&block) ⇒ Object
Execute sync action
128 129 130 131 132 133 134 135 136 137 138 139 |
# File 'lib/aspera/cli/sync_actions.rb', line 128 def execute_sync_action(&block) command = .get_next_command(%i[admin] + Sync::Operations::DIRECTIONS) # try to get 3 arguments as simple arguments case command when *Sync::Operations::DIRECTIONS Sync::Operations.start(async_info_from_args(direction: command), transfer.user_transfer_spec, &block) return Main.result_success when :admin return execute_sync_admin else Aspera.error_unexpected_value(command) end end |
#execute_sync_admin ⇒ Object
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 |
# File 'lib/aspera/cli/sync_actions.rb', line 96 def execute_sync_admin command2 = .get_next_command(%i[status find meta counters file_info overview]) require 'aspera/sync/database' unless command2.eql?(:status) case command2 when :status return Main.result_single_object(Sync::Operations.admin_status(async_info_from_args)) when :find folder = .get_next_argument('path') dbs = Sync::Operations.list_db_files(folder) return Main.result_object_list(dbs.keys.map{ |n| {name: n, path: dbs[n]}}) when :meta, :counters return Main.result_single_object(db_from_args.send(command2)) when :file_info result = db_from_args.send(command2) result.each do |r| r['sstate'] = SyncActions::STATE_STR[r['state']] if r['state'] end return Main.result_object_list( result, fields: %w[sstate record_id f_meta_path message] ) when :overview return Main.result_object_list( db_from_args.overview, fields: %w[table name type] ) else Aspera.error_unexpected_value(command2) end end |