Class: PactBroker::Versions::Repository

Inherits:
Object
  • Object
show all
Includes:
Repositories::Helpers
Defined in:
lib/pact_broker/versions/repository.rb

Instance Method Summary collapse

Methods included from Repositories::Helpers

#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) # Need to reload with populated order
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