abt-cli 0.0.12 → 0.0.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 4f1631b9069ca5094ba301eb3ccc5cf42da8e48a85b2678e8499cea1e9e4551c
4
- data.tar.gz: cd9dc57e8a6276de5a2bca61e59fb537bc8887901615d7ec86f2c4a59145f76c
3
+ metadata.gz: f61e3ba3cf1e1f6b5b69502861814a80b763849a7a9e8d654a593b55bf53b1bb
4
+ data.tar.gz: 497d18071f5a32cc4df92d2075a097452ffa2ffbf7f97ab98916678e6c92fa31
5
5
  SHA512:
6
- metadata.gz: bdca57213f85db7a3604ac1a5ed50a16a2918fded5b3b3e090e52aeb184414345d7609f08ef5145f205cf3fb9f1576f9e0aaa6b25a2e41684cfd506bed19e851
7
- data.tar.gz: d7eb95a22516aa0f894262e0a1b52ee659736b88775936040a87db03260711e12dbc6764674799b5d2f8bdb86cb14495f01440a0703d300759c3482db17a810a
6
+ metadata.gz: fa028736b67c70cd694a6e75665136e7829865d7afe66828262eae903aa553d5dc92478957e9e36526669f96fde1aa42ccab0036e2c1319f6db6cc47cfd033e4
7
+ data.tar.gz: 01af79206699568177e2548cd2662012f63ea996c6289a7dc49795fb99f06ff157692a51df444505336c3851a1f562a63fef659ca046e03579e11123b1e8a7ba
data/bin/abt CHANGED
@@ -1,12 +1,6 @@
1
1
  #!/usr/bin/env ruby
2
2
  # frozen_string_literal: true
3
3
 
4
- require 'dry-inflector'
5
- require 'faraday'
6
- require 'oj'
7
- require 'open3'
8
- require 'stringio'
9
-
10
4
  require_relative '../lib/abt.rb'
11
5
 
12
6
  begin
data/lib/abt.rb CHANGED
@@ -1,5 +1,11 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'dry-inflector'
4
+ require 'faraday'
5
+ require 'oj'
6
+ require 'open3'
7
+ require 'stringio'
8
+
3
9
  Dir.glob("#{File.dirname(File.absolute_path(__FILE__))}/abt/*.rb").sort.each do |file|
4
10
  require file
5
11
  end
@@ -4,13 +4,17 @@ module Abt
4
4
  class GitConfig
5
5
  attr_reader :namespace, :scope
6
6
 
7
+ LOCAL_CONFIG_AVAILABLE_CHECK_COMMAND = 'git config --local -l'
8
+
7
9
  def self.local_available?
8
- @local_available ||= begin
9
- status = nil
10
- Open3.popen3('git config --local -l') do |_i, _o, _e, thread|
11
- status = thread.value
10
+ return @local_available if instance_variables.include?(:@local_available)
11
+
12
+ @local_available = begin
13
+ success = false
14
+ Open3.popen3(LOCAL_CONFIG_AVAILABLE_CHECK_COMMAND) do |_i, _o, _e, thread|
15
+ success = thread.value.success?
12
16
  end
13
- status.success?
17
+ success
14
18
  end
15
19
  end
16
20
 
@@ -6,13 +6,16 @@ module Abt
6
6
  class Api
7
7
  VERBS = %i[get post put].freeze
8
8
 
9
- attr_reader :organization_name, :project_name, :username, :access_token
9
+ CONDITIONAL_ACCESS_POLICY_ERROR_CODE = 'VS403463'
10
10
 
11
- def initialize(organization_name:, project_name:, username:, access_token:)
11
+ attr_reader :organization_name, :project_name, :username, :access_token, :cli
12
+
13
+ def initialize(organization_name:, project_name:, username:, access_token:, cli:)
12
14
  @organization_name = organization_name
13
15
  @project_name = project_name
14
16
  @username = username
15
17
  @access_token = access_token
18
+ @cli = cli
16
19
  end
17
20
 
18
21
  VERBS.each do |verb|
@@ -50,6 +53,8 @@ module Abt
50
53
  encoded_response_body = response.body.force_encoding('utf-8')
51
54
  raise error_class, "Code: #{response.status}, body: #{encoded_response_body}"
52
55
  end
56
+ rescue Abt::HttpError::ForbiddenError => e
57
+ handle_denied_by_conditional_access_policy!(e)
53
58
  end
54
59
 
55
60
  def base_url
@@ -71,6 +76,19 @@ module Abt
71
76
  connection.headers['Accept'] = 'application/json; api-version=6.0'
72
77
  end
73
78
  end
79
+
80
+ private
81
+
82
+ def handle_denied_by_conditional_access_policy!(exception)
83
+ raise exception unless exception.message.include?(CONDITIONAL_ACCESS_POLICY_ERROR_CODE)
84
+
85
+ cli.abort <<~TXT
86
+ Access denied by conditional access policy.
87
+ Try logging into the board using the URL below, then retry the command.
88
+
89
+ #{base_url}
90
+ TXT
91
+ end
74
92
  end
75
93
  end
76
94
  end
@@ -89,7 +89,8 @@ module Abt
89
89
  Abt::Providers::Devops::Api.new(organization_name: organization_name,
90
90
  project_name: project_name,
91
91
  username: config.username_for_organization(organization_name),
92
- access_token: config.access_token_for_organization(organization_name))
92
+ access_token: config.access_token_for_organization(organization_name),
93
+ cli: cli)
93
94
  end
94
95
  end
95
96
  end
data/lib/abt/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Abt
4
- VERSION = '0.0.12'
4
+ VERSION = '0.0.13'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: abt-cli
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.12
4
+ version: 0.0.13
5
5
  platform: ruby
6
6
  authors:
7
7
  - Jesper Sørensen
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-02-01 00:00:00.000000000 Z
11
+ date: 2021-02-02 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: dry-inflector