Class: PactBroker::Versions::Repository
- Inherits:
-
Object
- Object
- PactBroker::Versions::Repository
show all
- Includes:
- Repositories::Helpers
- Defined in:
- lib/pact_broker/versions/repository.rb
Instance Method Summary
collapse
#case_sensitivity_options, #mysql?, #name_like, #order_ignore_case, #select_all_qualified, #select_for_subquery
Instance Method Details
#create(args) ⇒ Object
44
45
46
47
48
|
# File 'lib/pact_broker/versions/repository.rb', line 44
def create args
PactBroker.logger.info "Creating version #{args[:number]} for pacticipant_id=#{args[:pacticipant_id]}"
version = PactBroker::Domain::Version.new(number: args[:number], pacticipant_id: args[:pacticipant_id]).save
PactBroker::Domain::Version.find(id: version.id) end
|
#delete_by_id(version_ids) ⇒ Object
58
59
60
|
# File 'lib/pact_broker/versions/repository.rb', line 58
def delete_by_id version_ids
Sequel::Model.db[:versions].where(id: version_ids).delete
end
|
#find_by_pacticipant_id_and_number(pacticipant_id, number) ⇒ Object
11
12
13
|
# File 'lib/pact_broker/versions/repository.rb', line 11
def find_by_pacticipant_id_and_number pacticipant_id, number
PactBroker::Domain::Version.where(number: number, pacticipant_id: pacticipant_id).single_record
end
|
#find_by_pacticipant_id_and_number_or_create(pacticipant_id, number) ⇒ Object
50
51
52
53
54
55
56
|
# File 'lib/pact_broker/versions/repository.rb', line 50
def find_by_pacticipant_id_and_number_or_create pacticipant_id, number
if version = find_by_pacticipant_id_and_number(pacticipant_id, number)
version
else
create(pacticipant_id: pacticipant_id, number: number)
end
end
|
#find_by_pacticipant_name_and_number(pacticipant_name, number) ⇒ Object
35
36
37
38
39
40
41
42
|
# File 'lib/pact_broker/versions/repository.rb', line 35
def find_by_pacticipant_name_and_number pacticipant_name, number
PactBroker::Domain::Version
.select(Sequel[:versions][:id], Sequel[:versions][:number], Sequel[:versions][:pacticipant_id], Sequel[:versions][:order], Sequel[:versions][:created_at], Sequel[:versions][:updated_at])
.join(:pacticipants, {id: :pacticipant_id})
.where(name_like(:number, number))
.where(name_like(:name, pacticipant_name))
.single_record
end
|
#find_by_pacticpant_name_and_latest_tag(pacticipant_name, tag) ⇒ Object
15
16
17
18
19
20
21
22
23
24
|
# File 'lib/pact_broker/versions/repository.rb', line 15
def find_by_pacticpant_name_and_latest_tag pacticipant_name, tag
PactBroker::Domain::Version
.select_all_qualified
.join(:pacticipants, {id: :pacticipant_id}, {implicit_qualifier: :versions})
.join(:tags, {version_id: :id}, {implicit_qualifier: :versions})
.where(name_like(Sequel[:tags][:name], tag))
.where(name_like(Sequel[:pacticipants][:name], pacticipant_name))
.reverse_order(:order)
.first
end
|
#find_latest_by_pacticpant_name(pacticipant_name) ⇒ Object
26
27
28
29
30
31
32
33
|
# File 'lib/pact_broker/versions/repository.rb', line 26
def find_latest_by_pacticpant_name pacticipant_name
PactBroker::Domain::Version
.select_all_qualified
.join(:pacticipants, {id: :pacticipant_id}, {implicit_qualifier: :versions})
.where(name_like(Sequel[:pacticipants][:name], pacticipant_name))
.reverse_order(:order)
.first
end
|