require 'pact_broker/db' require 'pact_broker/domain/order_versions' require 'pact_broker/repositories/helpers' require 'pact_broker/tags/tag_with_latest_flag' module PactBroker module Domain class Version < Sequel::Model plugin :timestamps, update_on_create: true plugin :insert_ignore, identifying_columns: [:pacticipant_id, :number] set_primary_key :id one_to_many :pact_publications, order: :revision_number, class: "PactBroker::Pacts::PactPublication", key: :consumer_version_id associate(:many_to_one, :pacticipant, :class => "PactBroker::Domain::Pacticipant", :key => :pacticipant_id, :primary_key => :id) one_to_many :tags, :reciprocal => :version, order: :created_at one_to_many :tags_with_latest_flag, class: "PactBroker::Tags::TagWithLatestFlag", key: :version_id, primary_key: :id dataset_module do include PactBroker::Repositories::Helpers def where_pacticipant_name(pacticipant_name) join(:pacticipants) do | p | Sequel.&( { Sequel[first_source_alias][:pacticipant_id] => Sequel[p][:id] }, name_like(Sequel[p][:name], pacticipant_name) ) end end def where_tag(tag) if tag == true join(:tags, Sequel[:tags][:version_id] => Sequel[first_source_alias][:id]) else join(:tags) do | tags | Sequel.&( { Sequel[first_source_alias][:id] => Sequel[tags][:version_id] }, name_like(Sequel[tags][:name], tag) ) end end end def where_number(number) where(name_like(:number, number)) end def where_age_less_than(days) start_date = Date.today - days where{ versions[:created_at] >= start_date } end def delete PactBroker::Domain::Tag.where(version: self).delete super end def for_selector(selector) query = self query = query.where_pacticipant_name(selector.pacticipant_name) if selector.pacticipant_name query = query.where_tag(selector.tag) if selector.tag query = query.where_number(selector.pacticipant_version_number) if selector.pacticipant_version_number query = query.where_age_less_than(selector.max_age) if selector.max_age if selector.latest calculate_max_version_order_and_join_back_to_versions(query, selector) else query end end # private def calculate_max_version_order_and_join_back_to_versions(query, selector) versions_join = { Sequel[:versions][:pacticipant_id] => Sequel[:latest][:pacticipant_id], Sequel[:versions][:order] => Sequel[:latest][:latest_version_order] } group_by_cols = selector.tag == true ? [:pacticipant_id, Sequel[:tags][:name]] : [:pacticipant_id] max_order_for_each_pacticipant = query .select_group(*group_by_cols) .select_append{ max(order).as(latest_version_order) } join(max_order_for_each_pacticipant, versions_join, table_alias: :latest) end end def after_create super OrderVersions.(self) refresh end def before_destroy PactBroker::Domain::Tag.where(version: self).destroy super end def to_s "Version: number=#{number}, pacticipant=#{pacticipant_id}" end def version_and_updated_date "Version #{number} - #{updated_at.to_time.localtime.strftime("%d/%m/%Y")}" end # What about provider??? This makes no sense def latest_pact_publication pact_publications.last end end end end # Table: versions # Columns: # id | integer | PRIMARY KEY DEFAULT nextval('versions_id_seq'::regclass) # number | text | # repository_ref | text | # pacticipant_id | integer | NOT NULL # order | integer | # created_at | timestamp without time zone | NOT NULL # updated_at | timestamp without time zone | NOT NULL # Indexes: # versions_pkey | PRIMARY KEY btree (id) # uq_ver_ppt_ord | UNIQUE btree (pacticipant_id, "order") # versions_pacticipant_id_number_index | UNIQUE btree (pacticipant_id, number) # ndx_ver_num | btree (number) # ndx_ver_ord | btree ("order") # Foreign key constraints: # versions_pacticipant_id_fkey | (pacticipant_id) REFERENCES pacticipants(id) # Referenced By: # tags | tags_version_id_fkey | (version_id) REFERENCES versions(id) # pact_publications | pact_publications_consumer_version_id_fkey | (consumer_version_id) REFERENCES versions(id) # verifications | fk_verifications_versions | (provider_version_id) REFERENCES versions(id) # latest_pact_publication_ids_for_consumer_versions | latest_pact_publication_ids_for_consum_consumer_version_id_fkey | (consumer_version_id) REFERENCES versions(id) ON DELETE CASCADE # latest_verification_id_for_pact_version_and_provider_version | latest_v_id_for_pv_and_pv_provider_version_id_fk | (provider_version_id) REFERENCES versions(id) ON DELETE CASCADE