Class: Spaceship::Client
- Inherits:
-
Object
- Object
- Spaceship::Client
- Defined in:
- lib/spaceship/ui.rb,
lib/spaceship/portal/ui/select_team.rb,
lib/spaceship/client.rb
Direct Known Subclasses
Defined Under Namespace
Classes: AppleTimeoutError, InvalidUserCredentialsError, NoUserCredentialsError, UnexpectedResponse, UserInterface
Constant Summary collapse
- PROTOCOL_VERSION =
"QH65B2"- USER_AGENT =
"Spaceship #{Spaceship::VERSION}"
Instance Attribute Summary collapse
-
#client ⇒ Object
readonly
Returns the value of attribute client.
-
#logger ⇒ Object
The logger in which all requests are logged /tmp/spaceship.log by default.
-
#user ⇒ Object
The user that is currently logged in.
Automatic Paging collapse
-
#page_size ⇒ Object
The page size we want to request, defaults to 500.
-
#paging ⇒ Object
Handles the paging for you…
Login and Team Selection collapse
-
#login(user = nil, password = nil) ⇒ Spaceship::Client
Authenticates with Apple’s web services.
- #with_retry(tries = 5, &block) ⇒ Object
Class Method Summary collapse
- .hostname ⇒ Object
-
.login(user = nil, password = nil) ⇒ Spaceship::Client
Authenticates with Apple’s web services.
Instance Method Summary collapse
-
#cookie ⇒ String
Return the session cookie.
-
#initialize ⇒ Client
constructor
A new instance of Client.
-
#UI ⇒ Object
Public getter for all UI related code rubocop:disable Style/MethodName.
Constructor Details
#initialize ⇒ Client
Returns a new instance of Client.
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 |
# File 'lib/spaceship/client.rb', line 68 def initialize = HTTP::CookieJar.new @client = Faraday.new(self.class.hostname) do |c| c.response :json, content_type: /\bjson$/ c.response :xml, content_type: /\bxml$/ c.response :plist, content_type: /\bplist$/ c.use :cookie_jar, jar: c.adapter Faraday.default_adapter if ENV['DEBUG'] # for debugging only # This enables tracking of networking requests using Charles Web Proxy c.response :logger c.proxy "https://127.0.0.1:8888" end end end |
Instance Attribute Details
#client ⇒ Object (readonly)
Returns the value of attribute client.
22 23 24 |
# File 'lib/spaceship/client.rb', line 22 def client @client end |
#logger ⇒ Object
The logger in which all requests are logged /tmp/spaceship.log by default
29 30 31 |
# File 'lib/spaceship/client.rb', line 29 def logger @logger end |
#user ⇒ Object
The user that is currently logged in
25 26 27 |
# File 'lib/spaceship/client.rb', line 25 def user @user end |
Class Method Details
.hostname ⇒ Object
64 65 66 |
# File 'lib/spaceship/client.rb', line 64 def self.hostname raise "You must implemented self.hostname" end |
.login(user = nil, password = nil) ⇒ Spaceship::Client
Authenticates with Apple’s web services. This method has to be called once to generate a valid session. The session will automatically be used from then on.
This method will automatically use the username from the Appfile (if available) and fetch the password from the Keychain (if available)
55 56 57 58 59 60 61 62 |
# File 'lib/spaceship/client.rb', line 55 def self.login(user = nil, password = nil) instance = self.new if instance.login(user, password) instance else raise InvalidUserCredentialsError.new, "Invalid User Credentials" end end |
Instance Method Details
#cookie ⇒ String
Return the session cookie.
110 111 112 |
# File 'lib/spaceship/client.rb', line 110 def .map(&:to_s).join(';') end |
#login(user = nil, password = nil) ⇒ Spaceship::Client
Authenticates with Apple’s web services. This method has to be called once to generate a valid session. The session will automatically be used from then on.
This method will automatically use the username from the Appfile (if available) and fetch the password from the Keychain (if available)
157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 |
# File 'lib/spaceship/client.rb', line 157 def login(user = nil, password = nil) if user.to_s.empty? or password.to_s.empty? require 'credentials_manager' keychain_entry = CredentialsManager::AccountManager.new(user: user, password: password) user ||= keychain_entry.user password = keychain_entry.password end if user.to_s.strip.empty? or password.to_s.strip.empty? raise NoUserCredentialsError.new, "No login data provided" end self.user = user begin send_login_request(user, password) # different in subclasses rescue InvalidUserCredentialsError => ex raise ex unless keychain_entry if keychain_entry.invalid_credentials login(user) else puts "Please run this tool again to apply the new password" end end end |
#page_size ⇒ Object
The page size we want to request, defaults to 500
119 120 121 |
# File 'lib/spaceship/client.rb', line 119 def page_size @page_size ||= 500 end |
#paging ⇒ Object
Handles the paging for you… for free Just pass a block and use the parameter as page number
125 126 127 128 129 130 131 132 133 134 135 136 137 138 |
# File 'lib/spaceship/client.rb', line 125 def paging page = 0 results = [] loop do page += 1 current = yield(page) results += current break if (current || []).count < page_size # no more results end return results end |
#UI ⇒ Object
Public getter for all UI related code rubocop:disable Style/MethodName
11 12 13 |
# File 'lib/spaceship/ui.rb', line 11 def UI UserInterface.new(self) end |
#with_retry(tries = 5, &block) ⇒ Object
185 186 187 188 189 190 191 192 193 194 195 |
# File 'lib/spaceship/client.rb', line 185 def with_retry(tries = 5, &block) return block.call rescue Faraday::Error::TimeoutError, AppleTimeoutError => ex # New Faraday version: Faraday::TimeoutError => ex unless (tries -= 1).zero? logger.warn("Timeout received: '#{ex.message}'. Retrying after 3 seconds (remaining: #{tries})...") sleep 3 retry end raise ex # re-raise the exception end |