Module: Gitchefsync::Parser

Defined in:
lib/gitchefsync/opts.rb

Class Method Summary collapse

Class Method Details

.parseOpts(args) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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
# File 'lib/gitchefsync/opts.rb', line 7

def self.parseOpts (args)
  options = {}
  begin

    opt_parser = OptionParser.new do |opts|
      opts.banner = "Usage: sync_all.rb --private_token=xyz OR LDAP credentials"
      options[:private_token] = ''
      opts.on('-t', '--private_token token','gitlab private token') do |token|
        options[:private_token] = token
      end
      options[:config_file] = './sync-config.json'
      opts.on('-c', '--config file','path to config file') do |token|
        options[:config_file] = token
      end
      options[:login] = ''
      opts.on('-l','--login login','Required when token not set') do ||
        options[:login] = 
      end
      options[:password] = ''
      opts.on('-p','--password password','Required when token not set') do |pass|
        options[:password] = pass
      end
      opts.on('-s','--syslog',"Enable syslog") do |syslog|
        options[:syslog] = true
      end
      opts.on('-u', '--giturl', "Gitlab url") do |giturl|
        Gitlab.endpoint = giturl
      end
    end

    opt_parser.parse! (args)

    json = File.read(options[:config_file])

    j_config = JSON.parse(json)
    options[:config] = j_config
    options[:git_local] = j_config['working_directory']
    options[:knife_config] = j_config['knife_file']
    options[:groups] = j_config['git_groups']
    options[:stage_cookbook_dir] = j_config['tmp_dir']

    #set gitlab token and ensure git url for backward compatibility
    if Gitlab.endpoint == nil
      Gitlab.endpoint = 'https://gitlab.rim.net/api/v3'
    end
    if options[:private_token].empty? && !options[:login].empty? && !options[:password].empty?
      puts "using credentials"
      options[:private_token] = Gitlab.session(options[:login],options[:password]).to_hash['private_token']
    end

  rescue Exception => e
    puts e.backtrace
    raise(ConfigError,e.message,e.backtrace)
  end
  options
end