Class: Proc::Client

Inherits:
Http::Client
  • Object
show all
Defined in:
lib/proc/client.rb

Constant Summary collapse

DEFAULT_HEADERS =
{
  "accept" => "application/json",
  "content-type" => "application/json"
}.freeze

Instance Method Summary collapse

Constructor Details

#initialize(authorization, scheme: "https", host: "proc.dev") ⇒ Client

Returns a new instance of Client.



39
40
41
42
43
44
45
# File 'lib/proc/client.rb', line 39

def initialize(authorization, scheme: "https", host: "proc.dev")
  @authorization = authorization
  @scheme = scheme
  @host = host

  super()
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(name, input = input_omitted = true, **arguments) ⇒ Object



126
127
128
129
130
131
132
# File 'lib/proc/client.rb', line 126

def method_missing(name, input = input_omitted = true, **arguments)
  if input_omitted
    Callable.new(name, client: self, arguments: arguments)
  else
    Callable.new(name, client: self, input: input, arguments: arguments)
  end
end

Instance Method Details

#[](proc) ⇒ Object



47
48
49
# File 'lib/proc/client.rb', line 47

def [](proc)
  Callable.new(proc, client: self)
end

#argument(name, **options) ⇒ Object Also known as: arg



138
139
140
# File 'lib/proc/client.rb', line 138

def argument(name, **options)
  Argument.new(name, **options)
end

#call(proc = nil, input = nil, **arguments) ⇒ Object



72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
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/proc/client.rb', line 72

def call(proc = nil, input = nil, **arguments)
  Async(logger: NullLogger) { |task|
    body = {"<>" => true}

    unless Proc.undefined?(input)
      body["<<"] = serialize_value(input)
    end

    arguments.each_pair do |key, value|
      body[key.to_s] = serialize_value(value)
    end

    headers = {
      "authorization" => "bearer #{@authorization}"
    }.merge(DEFAULT_HEADERS)

    begin
      response = super(:post, build_uri(proc), headers: headers, body: Oj.dump(body, mode: :custom), task: task)

      @remaining = response.headers["x-rate-limit-remaining"].to_s.to_i
      @resets_at = Time.at(response.headers["x-rate-limit-reset"].to_s.to_i)

      payload = Oj.load(response.read, mode: :compat)
    rescue
      raise Proc::Unavailable
    ensure
      response&.close
    end

    case response.status
    when 200
      payload[">>"]
    when 400
      raise Proc::Invalid, payload.dig("error", "message")
    when 401
      raise Proc::Unauthorized, payload.dig("error", "message")
    when 403
      raise Proc::Forbidden, payload.dig("error", "message")
    when 404
      raise Proc::Undefined, payload.dig("error", "message")
    when 408
      raise Proc::Timeout, payload.dig("error", "message")
    when 429
      raise Proc::Limited, payload.dig("error", "message")
    when 500
      raise Proc::Error, payload.dig("error", "message")
    when 508
      raise Proc::Error, payload.dig("error", "message")
    else
      raise Proc::Error, "unhandled"
    end
  }.wait
end

#remainingObject



51
52
53
54
55
56
57
# File 'lib/proc/client.rb', line 51

def remaining
  unless defined?(@remaining)
    self["ping"].call
  end

  @remaining
end

#resets_atObject



59
60
61
62
63
64
65
# File 'lib/proc/client.rb', line 59

def resets_at
  unless defined?(@resets_at)
    self["ping"].call
  end

  @resets_at
end

#respond_to_missing?(name) ⇒ Boolean

Returns:

  • (Boolean)


134
135
136
# File 'lib/proc/client.rb', line 134

def respond_to_missing?(name, *)
  true
end