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 'lib/gitlab/database_importers/security/training_providers/importer.rb')
-rw-r--r--lib/gitlab/database_importers/security/training_providers/importer.rb42
1 files changed, 42 insertions, 0 deletions
diff --git a/lib/gitlab/database_importers/security/training_providers/importer.rb b/lib/gitlab/database_importers/security/training_providers/importer.rb
new file mode 100644
index 00000000000..aa6a9f29c6d
--- /dev/null
+++ b/lib/gitlab/database_importers/security/training_providers/importer.rb
@@ -0,0 +1,42 @@
+# frozen_string_literal: true
+
+module Gitlab
+ module DatabaseImporters
+ module Security
+ module TrainingProviders
+ module Importer
+ KONTRA_DATA = {
+ name: 'Kontra',
+ description: "Kontra Application Security provides interactive developer security education that
+ enables engineers to quickly learn security best practices
+ and fix issues in their code by analysing real-world software security vulnerabilities.",
+ url: "https://application.security/api/webhook/gitlab/exercises/search"
+ }.freeze
+
+ SCW_DATA = {
+ name: 'Secure Code Warrior',
+ description: "Resolve vulnerabilities faster and confidently with
+ highly relevant and bite-sized secure coding learning.",
+ url: "https://integration-api.securecodewarrior.com/api/v1/trial"
+ }.freeze
+
+ module Security
+ class TrainingProvider < ApplicationRecord
+ self.table_name = 'security_training_providers'
+ end
+ end
+
+ def self.upsert_providers
+ current_time = Time.current
+ timestamps = { created_at: current_time, updated_at: current_time }
+
+ Security::TrainingProvider.upsert_all(
+ [KONTRA_DATA.merge(timestamps), SCW_DATA.merge(timestamps)],
+ unique_by: :index_security_training_providers_on_unique_name
+ )
+ end
+ end
+ end
+ end
+ end
+end