Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/models/ml/model.rb')
-rw-r--r--app/models/ml/model.rb14
1 files changed, 9 insertions, 5 deletions
diff --git a/app/models/ml/model.rb b/app/models/ml/model.rb
index 27f03ed5857..b6f7e9a0639 100644
--- a/app/models/ml/model.rb
+++ b/app/models/ml/model.rb
@@ -3,6 +3,7 @@
module Ml
class Model < ApplicationRecord
include Presentable
+ include Sortable
validates :project, :default_experiment, presence: true
validates :name,
@@ -15,15 +16,19 @@ module Ml
has_one :default_experiment, class_name: 'Ml::Experiment'
belongs_to :project
+ belongs_to :user
has_many :versions, class_name: 'Ml::ModelVersion'
+ has_many :metadata, class_name: 'Ml::ModelMetadata'
has_one :latest_version, -> { latest_by_model }, class_name: 'Ml::ModelVersion', inverse_of: :model
scope :including_latest_version, -> { includes(:latest_version) }
+ scope :including_project, -> { includes(:project) }
scope :with_version_count, -> {
left_outer_joins(:versions)
.select("ml_models.*, count(ml_model_versions.id) as version_count")
.group(:id)
}
+ scope :by_name, ->(name) { where("ml_models.name LIKE ?", "%#{sanitize_sql_like(name)}%") } # rubocop:disable GitlabSecurity/SqlInjection
scope :by_project, ->(project) { where(project_id: project.id) }
def valid_default_experiment?
@@ -33,13 +38,12 @@ module Ml
errors.add(:default_experiment) unless default_experiment.project_id == project_id
end
- def self.find_or_create(project, name, experiment)
- create_with(default_experiment: experiment)
- .find_or_create_by(project: project, name: name)
- end
-
def self.by_project_id_and_id(project_id, id)
find_by(project_id: project_id, id: id)
end
+
+ def self.by_project_id_and_name(project_id, name)
+ find_by(project_id: project_id, name: name)
+ end
end
end