semaphore_client 3.1.0 → 3.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +1 -1
- data/lib/semaphore_client/api/pipeline.rb +65 -0
- data/lib/semaphore_client/model/pipeline.rb +52 -0
- data/lib/semaphore_client/version.rb +1 -1
- data/lib/semaphore_client.rb +6 -0
- metadata +4 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e793695882132ac56777d359ac84177c59a37a21
|
4
|
+
data.tar.gz: 64be6e2635a066d7dc071cb24243080eabc97d6c
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: fb493fdc647993a9a50a646a669792a578b5ba66aa0d9e035da3db329fd5ee0121077917a2390588b121ce3ad14d35adb05bb308c515239ac5fb61509bb7e771
|
7
|
+
data.tar.gz: 83f1911bb8279c83b1c569d275842e5b6b6bfa3e5e51e80f689802da5f7c2ee040f590374be234e492f265a6d988677c3ed969703c8728a68e5ac14bab5e1edd
|
data/Gemfile.lock
CHANGED
@@ -0,0 +1,65 @@
|
|
1
|
+
class SemaphoreClient
|
2
|
+
module Api
|
3
|
+
class Pipeline
|
4
|
+
def initialize(http_client)
|
5
|
+
@http_client = http_client
|
6
|
+
end
|
7
|
+
|
8
|
+
|
9
|
+
def list(params = nil, options = {})
|
10
|
+
list!(params, options)
|
11
|
+
rescue SemaphoreClient::Exceptions::ResponseError
|
12
|
+
end
|
13
|
+
|
14
|
+
def list!(params = nil, options = {})
|
15
|
+
path = "/pipelines"
|
16
|
+
|
17
|
+
@http_client.get(path, params, options).body.map { |e| SemaphoreClient::Model::Pipeline.load(e) }
|
18
|
+
end
|
19
|
+
|
20
|
+
|
21
|
+
|
22
|
+
def create(params = nil, options = {})
|
23
|
+
create!(params, options)
|
24
|
+
rescue SemaphoreClient::Exceptions::ResponseError
|
25
|
+
end
|
26
|
+
|
27
|
+
def create!(params = nil, options = {})
|
28
|
+
path = "/pipelines"
|
29
|
+
response = @http_client.post(path, params, options)
|
30
|
+
|
31
|
+
SemaphoreClient::Model::Pipeline.load(response.body)
|
32
|
+
end
|
33
|
+
|
34
|
+
|
35
|
+
|
36
|
+
def get(id, params = nil, options = {})
|
37
|
+
get!(id, params, options)
|
38
|
+
rescue SemaphoreClient::Exceptions::ResponseError
|
39
|
+
end
|
40
|
+
|
41
|
+
def get!(id, params = nil, options = {})
|
42
|
+
path = "/pipelines/#{id}"
|
43
|
+
response = @http_client.get(path, params = {})
|
44
|
+
|
45
|
+
SemaphoreClient::Model::Pipeline.load(response.body)
|
46
|
+
end
|
47
|
+
|
48
|
+
|
49
|
+
|
50
|
+
def update(id, params = nil, options = {})
|
51
|
+
update!(id, params, options)
|
52
|
+
rescue SemaphoreClient::Exceptions::ResponseError
|
53
|
+
end
|
54
|
+
|
55
|
+
def update!(id, params = nil, options = {})
|
56
|
+
path = "/pipelines/#{id}"
|
57
|
+
response = @http_client.patch(path, params)
|
58
|
+
|
59
|
+
SemaphoreClient::Model::Pipeline.load(response.body)
|
60
|
+
end
|
61
|
+
|
62
|
+
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
class SemaphoreClient
|
2
|
+
module Model
|
3
|
+
class Pipeline
|
4
|
+
attr_reader :id
|
5
|
+
attr_accessor :terminate_request
|
6
|
+
|
7
|
+
def self.load(attributes)
|
8
|
+
new.load(attributes)
|
9
|
+
end
|
10
|
+
|
11
|
+
def self.create(attributes)
|
12
|
+
new.update(attributes)
|
13
|
+
end
|
14
|
+
|
15
|
+
def load(attributes)
|
16
|
+
attributes = symbolize_keys(attributes)
|
17
|
+
|
18
|
+
@id = attributes[:id] if attributes.key?(:id)
|
19
|
+
|
20
|
+
self
|
21
|
+
end
|
22
|
+
|
23
|
+
def update(attributes)
|
24
|
+
attributes = symbolize_keys(attributes)
|
25
|
+
|
26
|
+
updatable_keys = [:terminate_request]
|
27
|
+
|
28
|
+
if (attributes.keys - updatable_keys).any?
|
29
|
+
raise SemaphoreClient::Exceptions::AttributeNotAvailable
|
30
|
+
end
|
31
|
+
|
32
|
+
@terminate_request = attributes[:terminate_request] if attributes.key?(:terminate_request)
|
33
|
+
|
34
|
+
self
|
35
|
+
end
|
36
|
+
|
37
|
+
def serialize
|
38
|
+
object_hash = {
|
39
|
+
"terminate_request" => @terminate_request,
|
40
|
+
}
|
41
|
+
|
42
|
+
object_hash.delete_if { |_, value| value.nil? }
|
43
|
+
end
|
44
|
+
|
45
|
+
private
|
46
|
+
|
47
|
+
def symbolize_keys(hash)
|
48
|
+
Hash[hash.map { |key, value| [key.to_sym, value] }]
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
data/lib/semaphore_client.rb
CHANGED
@@ -14,6 +14,7 @@ require "semaphore_client/model/project"
|
|
14
14
|
require "semaphore_client/model/secret"
|
15
15
|
require "semaphore_client/model/env_var"
|
16
16
|
require "semaphore_client/model/config_file"
|
17
|
+
require "semaphore_client/model/pipeline"
|
17
18
|
require "semaphore_client/api/user"
|
18
19
|
require "semaphore_client/api/org"
|
19
20
|
require "semaphore_client/api/team"
|
@@ -21,6 +22,7 @@ require "semaphore_client/api/project"
|
|
21
22
|
require "semaphore_client/api/secret"
|
22
23
|
require "semaphore_client/api/env_var"
|
23
24
|
require "semaphore_client/api/config_file"
|
25
|
+
require "semaphore_client/api/pipeline"
|
24
26
|
|
25
27
|
class SemaphoreClient
|
26
28
|
API_URL = "https://api.semaphoreci.com"
|
@@ -63,6 +65,10 @@ class SemaphoreClient
|
|
63
65
|
@config_file_api ||= SemaphoreClient::Api::ConfigFile.new(http_client)
|
64
66
|
end
|
65
67
|
|
68
|
+
def pipelines
|
69
|
+
@pipeline_api ||= SemaphoreClient::Api::Pipeline.new(http_client)
|
70
|
+
end
|
71
|
+
|
66
72
|
private
|
67
73
|
|
68
74
|
def http_client
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: semaphore_client
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.
|
4
|
+
version: 3.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jovan Ivanović
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2018-02-
|
11
|
+
date: 2018-02-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: faraday
|
@@ -115,6 +115,7 @@ files:
|
|
115
115
|
- lib/semaphore_client/api/config_file.rb
|
116
116
|
- lib/semaphore_client/api/env_var.rb
|
117
117
|
- lib/semaphore_client/api/org.rb
|
118
|
+
- lib/semaphore_client/api/pipeline.rb
|
118
119
|
- lib/semaphore_client/api/project.rb
|
119
120
|
- lib/semaphore_client/api/secret.rb
|
120
121
|
- lib/semaphore_client/api/team.rb
|
@@ -124,6 +125,7 @@ files:
|
|
124
125
|
- lib/semaphore_client/model/config_file.rb
|
125
126
|
- lib/semaphore_client/model/env_var.rb
|
126
127
|
- lib/semaphore_client/model/org.rb
|
128
|
+
- lib/semaphore_client/model/pipeline.rb
|
127
129
|
- lib/semaphore_client/model/project.rb
|
128
130
|
- lib/semaphore_client/model/secret.rb
|
129
131
|
- lib/semaphore_client/model/team.rb
|