2014-09-02 18:07:02 +05:30
# This file is auto-generated from the current state of the database. Instead
# of editing this file, please use the migrations feature of Active Record to
# incrementally modify your database, and then regenerate this schema definition.
#
# Note that this schema.rb definition is the authoritative source for your
# database schema. If you need to create the application database on another
# system, you should be using db:schema:load, not running all the migrations
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
# you'll amass, the slower it'll run and the greater likelihood for issues).
#
# It's strongly recommended that you check this file into your version control system.
2019-12-16 22:33:55 +05:30
ActiveRecord :: Schema . define ( version : 2019_11_22_135327 ) do
2014-09-02 18:07:02 +05:30
# These are extensions that must be enabled in order to support this database
2016-06-02 11:05:42 +05:30
enable_extension " pg_trgm "
2019-12-16 22:33:55 +05:30
enable_extension " plpgsql "
2014-09-02 18:07:02 +05:30
2019-12-16 22:33:55 +05:30
create_table " abuse_reports " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " reporter_id "
t . integer " user_id "
t . text " message "
2015-09-11 14:41:01 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . text " message_html "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2015-09-11 14:41:01 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " alerts_service_data " , force : :cascade do | t |
t . integer " service_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " encrypted_token " , limit : 255
t . string " encrypted_token_iv " , limit : 255
t . index [ " service_id " ] , name : " index_alerts_service_data_on_service_id "
end
create_table " allowed_email_domains " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " group_id " , null : false
t . string " domain " , limit : 255 , null : false
t . index [ " group_id " ] , name : " index_allowed_email_domains_on_group_id "
end
create_table " analytics_cycle_analytics_group_stages " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " relative_position "
t . integer " start_event_identifier " , null : false
t . integer " end_event_identifier " , null : false
t . bigint " group_id " , null : false
t . bigint " start_event_label_id "
t . bigint " end_event_label_id "
t . boolean " hidden " , default : false , null : false
t . boolean " custom " , default : true , null : false
t . string " name " , limit : 255 , null : false
t . index [ " end_event_label_id " ] , name : " index_analytics_ca_group_stages_on_end_event_label_id "
t . index [ " group_id " , " name " ] , name : " index_analytics_ca_group_stages_on_group_id_and_name " , unique : true
t . index [ " group_id " ] , name : " index_analytics_ca_group_stages_on_group_id "
t . index [ " relative_position " ] , name : " index_analytics_ca_group_stages_on_relative_position "
t . index [ " start_event_label_id " ] , name : " index_analytics_ca_group_stages_on_start_event_label_id "
end
create_table " analytics_cycle_analytics_project_stages " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " relative_position "
t . integer " start_event_identifier " , null : false
t . integer " end_event_identifier " , null : false
t . bigint " project_id " , null : false
t . bigint " start_event_label_id "
t . bigint " end_event_label_id "
t . boolean " hidden " , default : false , null : false
t . boolean " custom " , default : true , null : false
t . string " name " , limit : 255 , null : false
t . index [ " end_event_label_id " ] , name : " index_analytics_ca_project_stages_on_end_event_label_id "
t . index [ " project_id " , " name " ] , name : " index_analytics_ca_project_stages_on_project_id_and_name " , unique : true
t . index [ " project_id " ] , name : " index_analytics_ca_project_stages_on_project_id "
t . index [ " relative_position " ] , name : " index_analytics_ca_project_stages_on_relative_position "
t . index [ " start_event_label_id " ] , name : " index_analytics_ca_project_stages_on_start_event_label_id "
end
create_table " analytics_language_trend_repository_languages " , id : false , force : :cascade do | t |
t . integer " file_count " , default : 0 , null : false
t . bigint " programming_language_id " , null : false
t . bigint " project_id " , null : false
t . integer " loc " , default : 0 , null : false
t . integer " bytes " , default : 0 , null : false
t . integer " percentage " , limit : 2 , default : 0 , null : false
t . date " snapshot_date " , null : false
t . index [ " programming_language_id " , " project_id " , " snapshot_date " ] , name : " analytics_repository_languages_unique_index " , unique : true
t . index [ " project_id " ] , name : " analytics_repository_languages_on_project_id "
end
create_table " appearances " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " title " , null : false
t . text " description " , null : false
2016-11-03 12:29:30 +05:30
t . string " logo "
2019-12-16 22:33:55 +05:30
t . integer " updated_by "
t . string " header_logo "
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2016-11-03 12:29:30 +05:30
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2018-03-17 18:26:18 +05:30
t . text " new_project_guidelines "
t . text " new_project_guidelines_html "
2019-12-16 22:33:55 +05:30
t . text " header_message "
t . text " header_message_html "
t . text " footer_message "
t . text " footer_message_html "
t . text " message_background_color "
t . text " message_font_color "
2018-11-08 19:23:39 +05:30
t . string " favicon "
2019-12-16 22:33:55 +05:30
t . boolean " email_header_and_footer_enabled " , default : false , null : false
2016-04-02 18:10:28 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " application_setting_terms " , id : :serial , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " cached_markdown_version "
t . text " terms " , null : false
t . text " terms_html "
end
2019-12-16 22:33:55 +05:30
create_table " application_settings " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " default_projects_limit "
t . boolean " signup_enabled "
t . boolean " gravatar_enabled "
t . text " sign_in_text "
2015-04-26 12:48:37 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " home_page_url "
t . integer " default_branch_protection " , default : 2
2019-12-16 22:33:55 +05:30
t . text " help_text "
2016-11-03 12:29:30 +05:30
t . text " restricted_visibility_levels "
t . boolean " version_check_enabled " , default : true
t . integer " max_attachment_size " , default : 10 , null : false
t . integer " default_project_visibility "
t . integer " default_snippet_visibility "
t . text " domain_whitelist "
t . boolean " user_oauth_applications " , default : true
t . string " after_sign_out_path "
t . integer " session_expire_delay " , default : 10080 , null : false
t . text " import_sources "
t . text " help_page_text "
t . string " admin_notification_email "
t . boolean " shared_runners_enabled " , default : true , null : false
t . integer " max_artifacts_size " , default : 100 , null : false
t . string " runners_registration_token "
2017-08-17 22:00:37 +05:30
t . integer " max_pages_size " , default : 100 , null : false
2016-11-03 12:29:30 +05:30
t . boolean " require_two_factor_authentication " , default : false
t . integer " two_factor_grace_period " , default : 48
t . boolean " metrics_enabled " , default : false
t . string " metrics_host " , default : " localhost "
t . integer " metrics_pool_size " , default : 16
t . integer " metrics_timeout " , default : 10
t . integer " metrics_method_call_threshold " , default : 10
t . boolean " recaptcha_enabled " , default : false
t . integer " metrics_port " , default : 8089
t . boolean " akismet_enabled " , default : false
t . integer " metrics_sample_interval " , default : 15
t . boolean " email_author_in_body " , default : false
t . integer " default_group_visibility "
t . boolean " repository_checks_enabled " , default : false
t . text " shared_runners_text "
t . integer " metrics_packet_size " , default : 1
t . text " disabled_oauth_sign_in_sources "
t . string " health_check_access_token "
t . boolean " send_user_confirmation_email " , default : false
t . integer " container_registry_token_expire_delay " , default : 5
t . text " after_sign_up_text "
t . boolean " user_default_external " , default : false , null : false
2019-12-16 22:33:55 +05:30
t . boolean " elasticsearch_indexing " , default : false , null : false
t . boolean " elasticsearch_search " , default : false , null : false
2016-11-24 13:41:30 +05:30
t . string " repository_storages " , default : " default "
2016-11-03 12:29:30 +05:30
t . string " enabled_git_access_protocol "
t . boolean " domain_blacklist_enabled " , default : false
t . text " domain_blacklist "
2017-08-17 22:00:37 +05:30
t . boolean " usage_ping_enabled " , default : true , null : false
2016-11-03 12:29:30 +05:30
t . text " sign_in_text_html "
t . text " help_page_text_html "
t . text " shared_runners_text_html "
t . text " after_sign_up_text_html "
2018-03-17 18:26:18 +05:30
t . integer " rsa_key_restriction " , default : 0 , null : false
2018-11-08 19:23:39 +05:30
t . integer " dsa_key_restriction " , default : - 1 , null : false
2018-03-17 18:26:18 +05:30
t . integer " ecdsa_key_restriction " , default : 0 , null : false
t . integer " ed25519_key_restriction " , default : 0 , null : false
2017-08-17 22:00:37 +05:30
t . boolean " housekeeping_enabled " , default : true , null : false
t . boolean " housekeeping_bitmaps_enabled " , default : true , null : false
t . integer " housekeeping_incremental_repack_period " , default : 10 , null : false
t . integer " housekeeping_full_repack_period " , default : 50 , null : false
t . integer " housekeeping_gc_period " , default : 200 , null : false
t . boolean " html_emails_enabled " , default : true
t . string " plantuml_url "
t . boolean " plantuml_enabled "
2019-12-16 22:33:55 +05:30
t . integer " shared_runners_minutes " , default : 0 , null : false
t . bigint " repository_size_limit " , default : 0
2017-08-17 22:00:37 +05:30
t . integer " terminal_max_session_time " , default : 0 , null : false
t . integer " unique_ips_limit_per_user "
t . integer " unique_ips_limit_time_window "
t . boolean " unique_ips_limit_enabled " , default : false , null : false
t . string " default_artifacts_expire_in " , default : " 0 " , null : false
2019-12-16 22:33:55 +05:30
t . string " elasticsearch_url " , default : " http://localhost:9200 "
t . boolean " elasticsearch_aws " , default : false , null : false
t . string " elasticsearch_aws_region " , default : " us-east-1 "
t . string " elasticsearch_aws_access_key "
t . integer " geo_status_timeout " , default : 10
2017-08-17 22:00:37 +05:30
t . string " uuid "
2019-02-15 15:39:39 +05:30
t . decimal " polling_interval_multiplier " , default : " 1.0 " , null : false
2019-12-16 22:33:55 +05:30
t . boolean " elasticsearch_experimental_indexer "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2019-12-16 22:33:55 +05:30
t . boolean " check_namespace_plan " , default : false , null : false
t . integer " mirror_max_delay " , default : 300 , null : false
t . integer " mirror_max_capacity " , default : 100 , null : false
t . integer " mirror_capacity_threshold " , default : 50 , null : false
2018-10-15 14:42:47 +05:30
t . boolean " prometheus_metrics_enabled " , default : true , null : false
2019-12-16 22:33:55 +05:30
t . boolean " authorized_keys_enabled " , default : true , null : false
2017-09-10 17:25:29 +05:30
t . boolean " help_page_hide_commercial_content " , default : false
t . string " help_page_support_url "
2019-12-16 22:33:55 +05:30
t . boolean " slack_app_enabled " , default : false
t . string " slack_app_id "
2017-09-10 17:25:29 +05:30
t . integer " performance_bar_allowed_group_id "
2019-12-16 22:33:55 +05:30
t . boolean " allow_group_owners_to_manage_ldap " , default : true , null : false
t . boolean " hashed_storage_enabled " , default : true , null : false
2018-03-17 18:26:18 +05:30
t . boolean " project_export_enabled " , default : true , null : false
2018-11-20 20:47:30 +05:30
t . boolean " auto_devops_enabled " , default : true , null : false
2018-03-17 18:26:18 +05:30
t . boolean " throttle_unauthenticated_enabled " , default : false , null : false
t . integer " throttle_unauthenticated_requests_per_period " , default : 3600 , null : false
t . integer " throttle_unauthenticated_period_in_seconds " , default : 3600 , null : false
t . boolean " throttle_authenticated_api_enabled " , default : false , null : false
t . integer " throttle_authenticated_api_requests_per_period " , default : 7200 , null : false
t . integer " throttle_authenticated_api_period_in_seconds " , default : 3600 , null : false
t . boolean " throttle_authenticated_web_enabled " , default : false , null : false
t . integer " throttle_authenticated_web_requests_per_period " , default : 7200 , null : false
t . integer " throttle_authenticated_web_period_in_seconds " , default : 3600 , null : false
t . integer " gitaly_timeout_default " , default : 55 , null : false
t . integer " gitaly_timeout_medium " , default : 30 , null : false
t . integer " gitaly_timeout_fast " , default : 10 , null : false
2019-12-16 22:33:55 +05:30
t . boolean " mirror_available " , default : true , null : false
t . boolean " password_authentication_enabled_for_web "
t . boolean " password_authentication_enabled_for_git " , default : true , null : false
2018-03-17 18:26:18 +05:30
t . string " auto_devops_domain "
2019-12-16 22:33:55 +05:30
t . boolean " external_authorization_service_enabled " , default : false , null : false
t . string " external_authorization_service_url "
t . string " external_authorization_service_default_label "
2018-03-17 18:26:18 +05:30
t . boolean " pages_domain_verification_enabled " , default : true , null : false
2018-11-20 20:47:30 +05:30
t . string " user_default_internal_regex "
2019-12-16 22:33:55 +05:30
t . float " external_authorization_service_timeout " , default : 0 . 5
t . text " external_auth_client_cert "
t . text " encrypted_external_auth_client_key "
t . string " encrypted_external_auth_client_key_iv "
t . string " encrypted_external_auth_client_key_pass "
t . string " encrypted_external_auth_client_key_pass_iv "
t . string " email_additional_text "
2018-10-15 14:42:47 +05:30
t . boolean " enforce_terms " , default : false
2019-12-16 22:33:55 +05:30
t . integer " file_template_project_id "
t . boolean " pseudonymizer_enabled " , default : false , null : false
2018-11-08 19:23:39 +05:30
t . boolean " hide_third_party_offers " , default : false , null : false
2019-12-16 22:33:55 +05:30
t . boolean " snowplow_enabled " , default : false , null : false
t . string " snowplow_collector_hostname "
t . string " snowplow_site_id "
t . string " snowplow_cookie_domain "
2018-11-18 11:00:15 +05:30
t . boolean " instance_statistics_visibility_private " , default : false , null : false
t . boolean " web_ide_clientside_preview_enabled " , default : false , null : false
2018-11-20 20:47:30 +05:30
t . boolean " user_show_add_ssh_key_message " , default : true , null : false
2019-12-16 22:33:55 +05:30
t . integer " custom_project_templates_group_id "
2018-11-20 20:47:30 +05:30
t . integer " usage_stats_set_by_user_id "
t . integer " receive_max_input_size "
2018-12-05 23:21:45 +05:30
t . integer " diff_max_patch_bytes " , default : 102400 , null : false
2018-12-13 13:39:08 +05:30
t . integer " archive_builds_in_seconds "
t . string " commit_email_hostname "
2019-02-15 15:39:39 +05:30
t . boolean " protected_ci_variables " , default : false , null : false
t . string " runners_registration_token_encrypted "
2019-03-02 22:35:43 +05:30
t . integer " local_markdown_version " , default : 0 , null : false
t . integer " first_day_of_week " , default : 0 , null : false
2019-12-16 22:33:55 +05:30
t . boolean " elasticsearch_limit_indexing " , default : false , null : false
t . integer " default_project_creation " , default : 2 , null : false
t . string " lets_encrypt_notification_email "
t . boolean " lets_encrypt_terms_of_service_accepted " , default : false , null : false
t . string " geo_node_allowed_ips " , default : " 0.0.0.0/0, ::/0 "
t . integer " elasticsearch_shards " , default : 5 , null : false
t . integer " elasticsearch_replicas " , default : 1 , null : false
t . text " encrypted_lets_encrypt_private_key "
t . text " encrypted_lets_encrypt_private_key_iv "
t . string " required_instance_ci_template "
t . boolean " dns_rebinding_protection_enabled " , default : true , null : false
t . boolean " default_project_deletion_protection " , default : false , null : false
t . boolean " grafana_enabled " , default : false , null : false
t . boolean " lock_memberships_to_ldap " , default : false , null : false
t . boolean " time_tracking_limit_to_hours " , default : false , null : false
t . string " grafana_url " , default : " /-/grafana " , null : false
t . boolean " login_recaptcha_protection_enabled " , default : false , null : false
t . string " outbound_local_requests_whitelist " , limit : 255 , default : [ ] , null : false , array : true
t . integer " raw_blob_request_limit " , default : 300 , null : false
t . boolean " allow_local_requests_from_web_hooks_and_services " , default : false , null : false
t . boolean " allow_local_requests_from_system_hooks " , default : true , null : false
t . bigint " instance_administration_project_id "
t . boolean " asset_proxy_enabled " , default : false , null : false
t . string " asset_proxy_url "
t . text " asset_proxy_whitelist "
t . text " encrypted_asset_proxy_secret_key "
t . string " encrypted_asset_proxy_secret_key_iv "
t . string " static_objects_external_storage_url " , limit : 255
t . string " static_objects_external_storage_auth_token " , limit : 255
t . text " encrypted_akismet_api_key "
t . string " encrypted_akismet_api_key_iv " , limit : 255
t . text " encrypted_elasticsearch_aws_secret_access_key "
t . string " encrypted_elasticsearch_aws_secret_access_key_iv " , limit : 255
t . text " encrypted_recaptcha_private_key "
t . string " encrypted_recaptcha_private_key_iv " , limit : 255
t . text " encrypted_recaptcha_site_key "
t . string " encrypted_recaptcha_site_key_iv " , limit : 255
t . text " encrypted_slack_app_secret "
t . string " encrypted_slack_app_secret_iv " , limit : 255
t . text " encrypted_slack_app_verification_token "
t . string " encrypted_slack_app_verification_token_iv " , limit : 255
t . index [ " custom_project_templates_group_id " ] , name : " index_application_settings_on_custom_project_templates_group_id "
t . index [ " file_template_project_id " ] , name : " index_application_settings_on_file_template_project_id "
t . index [ " instance_administration_project_id " ] , name : " index_applicationsettings_on_instance_administration_project_id "
t . index [ " usage_stats_set_by_user_id " ] , name : " index_application_settings_on_usage_stats_set_by_user_id "
end
create_table " approval_merge_request_rule_sources " , force : :cascade do | t |
t . bigint " approval_merge_request_rule_id " , null : false
t . bigint " approval_project_rule_id " , null : false
t . index [ " approval_merge_request_rule_id " ] , name : " index_approval_merge_request_rule_sources_1 " , unique : true
t . index [ " approval_project_rule_id " ] , name : " index_approval_merge_request_rule_sources_2 "
end
create_table " approval_merge_request_rules " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " merge_request_id " , null : false
t . integer " approvals_required " , limit : 2 , default : 0 , null : false
t . boolean " code_owner " , default : false , null : false
t . string " name " , null : false
t . integer " rule_type " , limit : 2 , default : 1 , null : false
t . integer " report_type " , limit : 2
t . index [ " merge_request_id " , " code_owner " , " name " ] , name : " approval_rule_name_index_for_code_owners " , unique : true , where : " (code_owner = true) "
t . index [ " merge_request_id " , " code_owner " ] , name : " index_approval_merge_request_rules_1 "
t . index [ " merge_request_id " , " name " ] , name : " index_approval_rule_name_for_code_owners_rule_type " , unique : true , where : " (rule_type = 2) "
t . index [ " merge_request_id " , " rule_type " ] , name : " any_approver_merge_request_rule_type_unique_index " , unique : true , where : " (rule_type = 4) "
t . index [ " merge_request_id " ] , name : " index_approval_rules_code_owners_rule_type " , where : " (rule_type = 2) "
end
create_table " approval_merge_request_rules_approved_approvers " , force : :cascade do | t |
t . bigint " approval_merge_request_rule_id " , null : false
t . integer " user_id " , null : false
t . index [ " approval_merge_request_rule_id " , " user_id " ] , name : " index_approval_merge_request_rules_approved_approvers_1 " , unique : true
t . index [ " user_id " ] , name : " index_approval_merge_request_rules_approved_approvers_2 "
end
create_table " approval_merge_request_rules_groups " , force : :cascade do | t |
t . bigint " approval_merge_request_rule_id " , null : false
t . integer " group_id " , null : false
t . index [ " approval_merge_request_rule_id " , " group_id " ] , name : " index_approval_merge_request_rules_groups_1 " , unique : true
t . index [ " group_id " ] , name : " index_approval_merge_request_rules_groups_2 "
end
create_table " approval_merge_request_rules_users " , force : :cascade do | t |
t . bigint " approval_merge_request_rule_id " , null : false
t . integer " user_id " , null : false
t . index [ " approval_merge_request_rule_id " , " user_id " ] , name : " index_approval_merge_request_rules_users_1 " , unique : true
t . index [ " user_id " ] , name : " index_approval_merge_request_rules_users_2 "
end
create_table " approval_project_rules " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " project_id " , null : false
t . integer " approvals_required " , limit : 2 , default : 0 , null : false
t . string " name " , null : false
t . integer " rule_type " , limit : 2 , default : 0 , null : false
t . index [ " project_id " ] , name : " any_approver_project_rule_type_unique_index " , unique : true , where : " (rule_type = 3) "
t . index [ " project_id " ] , name : " index_approval_project_rules_on_project_id "
t . index [ " rule_type " ] , name : " index_approval_project_rules_on_rule_type "
end
create_table " approval_project_rules_groups " , force : :cascade do | t |
t . bigint " approval_project_rule_id " , null : false
t . integer " group_id " , null : false
t . index [ " approval_project_rule_id " , " group_id " ] , name : " index_approval_project_rules_groups_1 " , unique : true
t . index [ " group_id " ] , name : " index_approval_project_rules_groups_2 "
end
create_table " approval_project_rules_users " , force : :cascade do | t |
t . bigint " approval_project_rule_id " , null : false
t . integer " user_id " , null : false
t . index [ " approval_project_rule_id " , " user_id " ] , name : " index_approval_project_rules_users_1 " , unique : true
t . index [ " user_id " ] , name : " index_approval_project_rules_users_2 "
end
create_table " approvals " , id : :serial , force : :cascade do | t |
t . integer " merge_request_id " , null : false
t . integer " user_id " , null : false
t . datetime " created_at "
t . datetime " updated_at "
t . index [ " merge_request_id " ] , name : " index_approvals_on_merge_request_id "
t . index [ " user_id " , " merge_request_id " ] , name : " index_approvals_on_user_id_and_merge_request_id " , unique : true
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " approver_groups " , id : :serial , force : :cascade do | t |
t . integer " target_id " , null : false
t . string " target_type " , null : false
t . integer " group_id " , null : false
t . datetime " created_at "
t . datetime " updated_at "
t . index [ " group_id " ] , name : " index_approver_groups_on_group_id "
t . index [ " target_id " , " target_type " ] , name : " index_approver_groups_on_target_id_and_target_type "
end
create_table " approvers " , id : :serial , force : :cascade do | t |
t . integer " target_id " , null : false
t . string " target_type "
t . integer " user_id " , null : false
t . datetime " created_at "
t . datetime " updated_at "
t . index [ " target_id " , " target_type " ] , name : " index_approvers_on_target_id_and_target_type "
t . index [ " user_id " ] , name : " index_approvers_on_user_id "
end
create_table " audit_events " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " author_id " , null : false
t . string " type " , null : false
t . integer " entity_id " , null : false
t . string " entity_type " , null : false
t . text " details "
2015-09-11 14:41:01 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . index [ " created_at " , " author_id " ] , name : " analytics_index_audit_events_on_created_at_and_author_id "
t . index [ " entity_id " , " entity_type " ] , name : " index_audit_events_on_entity_id_and_entity_type "
2015-09-11 14:41:01 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " award_emoji " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " name "
t . integer " user_id "
t . integer " awardable_id "
t . string " awardable_type "
2016-06-16 23:09:34 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . index [ " awardable_type " , " awardable_id " ] , name : " index_award_emoji_on_awardable_type_and_awardable_id "
t . index [ " user_id " , " name " ] , name : " index_award_emoji_on_user_id_and_name "
2016-06-16 23:09:34 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " badges " , id : :serial , force : :cascade do | t |
2018-03-27 19:54:05 +05:30
t . string " link_url " , null : false
t . string " image_url " , null : false
t . integer " project_id "
t . integer " group_id "
t . string " type " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " group_id " ] , name : " index_badges_on_group_id "
t . index [ " project_id " ] , name : " index_badges_on_project_id "
end
create_table " board_assignees " , id : :serial , force : :cascade do | t |
t . integer " board_id " , null : false
t . integer " assignee_id " , null : false
t . index [ " assignee_id " ] , name : " index_board_assignees_on_assignee_id "
t . index [ " board_id " , " assignee_id " ] , name : " index_board_assignees_on_board_id_and_assignee_id " , unique : true
2018-03-27 19:54:05 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " board_group_recent_visits " , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " user_id "
t . integer " board_id "
t . integer " group_id "
2019-12-16 22:33:55 +05:30
t . index [ " board_id " ] , name : " index_board_group_recent_visits_on_board_id "
t . index [ " group_id " ] , name : " index_board_group_recent_visits_on_group_id "
t . index [ " user_id " , " group_id " , " board_id " ] , name : " index_board_group_recent_visits_on_user_group_and_board " , unique : true
t . index [ " user_id " ] , name : " index_board_group_recent_visits_on_user_id "
end
create_table " board_labels " , id : :serial , force : :cascade do | t |
t . integer " board_id " , null : false
t . integer " label_id " , null : false
t . index [ " board_id " , " label_id " ] , name : " index_board_labels_on_board_id_and_label_id " , unique : true
t . index [ " label_id " ] , name : " index_board_labels_on_label_id "
2018-12-13 13:39:08 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " board_project_recent_visits " , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " user_id "
t . integer " project_id "
t . integer " board_id "
2019-12-16 22:33:55 +05:30
t . index [ " board_id " ] , name : " index_board_project_recent_visits_on_board_id "
t . index [ " project_id " ] , name : " index_board_project_recent_visits_on_project_id "
t . index [ " user_id " , " project_id " , " board_id " ] , name : " index_board_project_recent_visits_on_user_project_and_board " , unique : true
t . index [ " user_id " ] , name : " index_board_project_recent_visits_on_user_id "
2018-12-13 13:39:08 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " boards " , id : :serial , force : :cascade do | t |
2018-03-27 19:54:05 +05:30
t . integer " project_id "
2016-09-13 17:45:13 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . string " name " , default : " Development " , null : false
t . integer " milestone_id "
2018-03-27 19:54:05 +05:30
t . integer " group_id "
2019-12-16 22:33:55 +05:30
t . integer " weight "
t . index [ " group_id " ] , name : " index_boards_on_group_id "
t . index [ " milestone_id " ] , name : " index_boards_on_milestone_id "
t . index [ " project_id " ] , name : " index_boards_on_project_id "
2016-09-13 17:45:13 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " broadcast_messages " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . text " message " , null : false
2017-09-10 17:25:29 +05:30
t . datetime " starts_at " , null : false
t . datetime " ends_at " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2016-11-03 12:29:30 +05:30
t . string " color "
t . string " font "
2017-09-10 17:25:29 +05:30
t . text " message_html " , null : false
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2019-12-16 22:33:55 +05:30
t . index [ " starts_at " , " ends_at " , " id " ] , name : " index_broadcast_messages_on_starts_at_and_ends_at_and_id "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " chat_names " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " user_id " , null : false
t . integer " service_id " , null : false
t . string " team_id " , null : false
t . string " team_domain "
t . string " chat_id " , null : false
t . string " chat_name "
t . datetime " last_used_at "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " service_id " , " team_id " , " chat_id " ] , name : " index_chat_names_on_service_id_and_team_id_and_chat_id " , unique : true
t . index [ " user_id " , " service_id " ] , name : " index_chat_names_on_user_id_and_service_id " , unique : true
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " chat_teams " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " namespace_id " , null : false
t . string " team_id "
t . string " name "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " namespace_id " ] , name : " index_chat_teams_on_namespace_id " , unique : true
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_build_needs " , id : :serial , force : :cascade do | t |
t . integer " build_id " , null : false
t . text " name " , null : false
t . index [ " build_id " , " name " ] , name : " index_ci_build_needs_on_build_id_and_name " , unique : true
end
create_table " ci_build_trace_chunks " , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " build_id " , null : false
t . integer " chunk_index " , null : false
t . integer " data_store " , null : false
t . binary " raw_data "
2019-12-16 22:33:55 +05:30
t . index [ " build_id " , " chunk_index " ] , name : " index_ci_build_trace_chunks_on_build_id_and_chunk_index " , unique : true
2018-10-15 14:42:47 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_build_trace_section_names " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
t . string " name " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " , " name " ] , name : " index_ci_build_trace_section_names_on_project_id_and_name " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_build_trace_sections " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " date_start " , null : false
t . datetime " date_end " , null : false
2019-02-15 15:39:39 +05:30
t . bigint " byte_start " , null : false
t . bigint " byte_end " , null : false
2018-03-17 18:26:18 +05:30
t . integer " build_id " , null : false
t . integer " section_name_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " build_id " , " section_name_id " ] , name : " index_ci_build_trace_sections_on_build_id_and_section_name_id " , unique : true
t . index [ " project_id " ] , name : " index_ci_build_trace_sections_on_project_id "
t . index [ " section_name_id " ] , name : " index_ci_build_trace_sections_on_section_name_id "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_builds " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " status "
2015-09-25 12:07:36 +05:30
t . datetime " finished_at "
2016-11-03 12:29:30 +05:30
t . text " trace "
2015-09-25 12:07:36 +05:30
t . datetime " created_at "
t . datetime " updated_at "
t . datetime " started_at "
2016-11-03 12:29:30 +05:30
t . integer " runner_id "
t . float " coverage "
t . integer " commit_id "
t . text " commands "
t . string " name "
t . text " options "
t . boolean " allow_failure " , default : false , null : false
t . string " stage "
t . integer " trigger_request_id "
t . integer " stage_idx "
t . boolean " tag "
t . string " ref "
t . integer " user_id "
t . string " type "
t . string " target_url "
t . string " description "
t . text " artifacts_file "
2017-08-17 22:00:37 +05:30
t . integer " project_id "
2016-11-03 12:29:30 +05:30
t . text " artifacts_metadata "
t . integer " erased_by_id "
2016-04-02 18:10:28 +05:30
t . datetime " erased_at "
2016-06-16 23:09:34 +05:30
t . datetime " artifacts_expire_at "
2016-11-03 12:29:30 +05:30
t . string " environment "
2019-02-15 15:39:39 +05:30
t . bigint " artifacts_size "
2016-11-03 12:29:30 +05:30
t . string " when "
t . text " yaml_variables "
2016-09-13 17:45:13 +05:30
t . datetime " queued_at "
2016-11-03 12:29:30 +05:30
t . string " token "
2017-08-17 22:00:37 +05:30
t . integer " lock_version "
t . string " coverage_regex "
t . integer " auto_canceled_by_id "
t . boolean " retried "
2017-09-10 17:25:29 +05:30
t . integer " stage_id "
2018-05-09 12:01:36 +05:30
t . integer " artifacts_file_store "
t . integer " artifacts_metadata_store "
2018-03-17 18:26:18 +05:30
t . boolean " protected "
t . integer " failure_reason "
2018-12-05 23:21:45 +05:30
t . datetime_with_timezone " scheduled_at "
2019-02-15 15:39:39 +05:30
t . string " token_encrypted "
2019-12-16 22:33:55 +05:30
t . integer " upstream_pipeline_id "
t . index [ " artifacts_expire_at " ] , name : " index_ci_builds_on_artifacts_expire_at " , where : " (artifacts_file <> ''::text) "
t . index [ " auto_canceled_by_id " ] , name : " index_ci_builds_on_auto_canceled_by_id "
t . index [ " commit_id " , " artifacts_expire_at " , " id " ] , name : " index_ci_builds_on_commit_id_and_artifacts_expireatandidpartial " , where : " (((type)::text = 'Ci::Build'::text) AND ((retried = false) OR (retried IS NULL)) AND ((name)::text = ANY (ARRAY[('sast'::character varying)::text, ('dependency_scanning'::character varying)::text, ('sast:container'::character varying)::text, ('container_scanning'::character varying)::text, ('dast'::character varying)::text]))) "
t . index [ " commit_id " , " stage_idx " , " created_at " ] , name : " index_ci_builds_on_commit_id_and_stage_idx_and_created_at "
t . index [ " commit_id " , " status " , " type " ] , name : " index_ci_builds_on_commit_id_and_status_and_type "
t . index [ " commit_id " , " type " , " name " , " ref " ] , name : " index_ci_builds_on_commit_id_and_type_and_name_and_ref "
t . index [ " commit_id " , " type " , " ref " ] , name : " index_ci_builds_on_commit_id_and_type_and_ref "
t . index [ " name " ] , name : " index_ci_builds_on_name_for_security_products_values " , where : " ((name)::text = ANY (ARRAY[('container_scanning'::character varying)::text, ('dast'::character varying)::text, ('dependency_scanning'::character varying)::text, ('license_management'::character varying)::text, ('sast'::character varying)::text])) "
t . index [ " project_id " , " id " ] , name : " index_ci_builds_on_project_id_and_id "
t . index [ " project_id " , " status " ] , name : " index_ci_builds_project_id_and_status_for_live_jobs_partial2 " , where : " (((type)::text = 'Ci::Build'::text) AND ((status)::text = ANY (ARRAY[('running'::character varying)::text, ('pending'::character varying)::text, ('created'::character varying)::text]))) "
t . index [ " protected " ] , name : " index_ci_builds_on_protected "
t . index [ " queued_at " ] , name : " index_ci_builds_on_queued_at "
t . index [ " runner_id " ] , name : " index_ci_builds_on_runner_id "
t . index [ " scheduled_at " ] , name : " partial_index_ci_builds_on_scheduled_at_with_scheduled_jobs " , where : " ((scheduled_at IS NOT NULL) AND ((type)::text = 'Ci::Build'::text) AND ((status)::text = 'scheduled'::text)) "
t . index [ " stage_id " , " stage_idx " ] , name : " tmp_build_stage_position_index " , where : " (stage_idx IS NOT NULL) "
t . index [ " stage_id " ] , name : " index_ci_builds_on_stage_id "
t . index [ " status " , " created_at " , " project_id " ] , name : " ci_builds_gitlab_monitor_metrics " , where : " ((type)::text = 'Ci::Build'::text) "
t . index [ " status " , " type " , " runner_id " ] , name : " index_ci_builds_on_status_and_type_and_runner_id "
t . index [ " token " ] , name : " index_ci_builds_on_token " , unique : true
t . index [ " token_encrypted " ] , name : " index_ci_builds_on_token_encrypted " , unique : true , where : " (token_encrypted IS NOT NULL) "
t . index [ " updated_at " ] , name : " index_ci_builds_on_updated_at "
t . index [ " upstream_pipeline_id " ] , name : " index_ci_builds_on_upstream_pipeline_id " , where : " (upstream_pipeline_id IS NOT NULL) "
t . index [ " user_id " ] , name : " index_ci_builds_on_user_id "
end
create_table " ci_builds_metadata " , id : :serial , force : :cascade do | t |
2018-05-09 12:01:36 +05:30
t . integer " build_id " , null : false
t . integer " project_id " , null : false
t . integer " timeout "
t . integer " timeout_source " , default : 1 , null : false
2019-12-16 22:33:55 +05:30
t . boolean " interruptible "
2019-02-15 15:39:39 +05:30
t . jsonb " config_options "
t . jsonb " config_variables "
2019-12-16 22:33:55 +05:30
t . index [ " build_id " ] , name : " index_ci_builds_metadata_on_build_id " , unique : true
t . index [ " build_id " ] , name : " index_ci_builds_metadata_on_build_id_and_interruptible " , where : " (interruptible = true) "
t . index [ " project_id " ] , name : " index_ci_builds_metadata_on_project_id "
2018-05-09 12:01:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_builds_runner_session " , force : :cascade do | t |
2018-11-08 19:23:39 +05:30
t . integer " build_id " , null : false
t . string " url " , null : false
t . string " certificate "
t . string " authorization "
2019-12-16 22:33:55 +05:30
t . index [ " build_id " ] , name : " index_ci_builds_runner_session_on_build_id " , unique : true
2018-11-08 19:23:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_group_variables " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " key " , null : false
t . text " value "
t . text " encrypted_value "
t . string " encrypted_value_salt "
t . string " encrypted_value_iv "
t . integer " group_id " , null : false
t . boolean " protected " , default : false , null : false
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . boolean " masked " , default : false , null : false
t . integer " variable_type " , limit : 2 , default : 1 , null : false
t . index [ " group_id " , " key " ] , name : " index_ci_group_variables_on_group_id_and_key " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_job_artifacts " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
t . integer " job_id " , null : false
t . integer " file_type " , null : false
2019-02-15 15:39:39 +05:30
t . bigint " size "
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . datetime_with_timezone " expire_at "
t . string " file "
2019-12-16 22:33:55 +05:30
t . integer " file_store "
2018-03-27 19:54:05 +05:30
t . binary " file_sha256 "
2018-11-18 11:00:15 +05:30
t . integer " file_format " , limit : 2
2018-11-20 20:47:30 +05:30
t . integer " file_location " , limit : 2
2019-12-16 22:33:55 +05:30
t . index [ " expire_at " , " job_id " ] , name : " index_ci_job_artifacts_on_expire_at_and_job_id "
t . index [ " file_store " ] , name : " index_ci_job_artifacts_on_file_store "
t . index [ " job_id " , " file_type " ] , name : " index_ci_job_artifacts_on_job_id_and_file_type " , unique : true
t . index [ " project_id " ] , name : " index_ci_job_artifacts_on_project_id "
t . index [ " project_id " ] , name : " index_ci_job_artifacts_on_project_id_for_security_reports " , where : " (file_type = ANY (ARRAY[5, 6, 7, 8])) "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_job_variables " , force : :cascade do | t |
t . string " key " , null : false
t . text " encrypted_value "
t . string " encrypted_value_iv "
t . bigint " job_id " , null : false
t . integer " variable_type " , limit : 2 , default : 1 , null : false
t . index [ " job_id " ] , name : " index_ci_job_variables_on_job_id "
t . index [ " key " , " job_id " ] , name : " index_ci_job_variables_on_key_and_job_id " , unique : true
end
create_table " ci_pipeline_chat_data " , force : :cascade do | t |
t . integer " pipeline_id " , null : false
t . integer " chat_name_id " , null : false
t . text " response_url " , null : false
t . index [ " chat_name_id " ] , name : " index_ci_pipeline_chat_data_on_chat_name_id "
t . index [ " pipeline_id " ] , name : " index_ci_pipeline_chat_data_on_pipeline_id " , unique : true
end
create_table " ci_pipeline_schedule_variables " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " key " , null : false
t . text " value "
t . text " encrypted_value "
t . string " encrypted_value_salt "
t . string " encrypted_value_iv "
t . integer " pipeline_schedule_id " , null : false
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at "
t . datetime_with_timezone " updated_at "
2019-12-16 22:33:55 +05:30
t . integer " variable_type " , limit : 2 , default : 1 , null : false
t . index [ " pipeline_schedule_id " , " key " ] , name : " index_ci_pipeline_schedule_variables_on_schedule_id_and_key " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_pipeline_schedules " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . string " description "
t . string " ref "
t . string " cron "
t . string " cron_timezone "
t . datetime " next_run_at "
2016-11-03 12:29:30 +05:30
t . integer " project_id "
2017-08-17 22:00:37 +05:30
t . integer " owner_id "
t . boolean " active " , default : true
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . index [ " next_run_at " , " active " ] , name : " index_ci_pipeline_schedules_on_next_run_at_and_active "
t . index [ " owner_id " ] , name : " index_ci_pipeline_schedules_on_owner_id "
t . index [ " project_id " ] , name : " index_ci_pipeline_schedules_on_project_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_pipeline_variables " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " key " , null : false
t . text " value "
t . text " encrypted_value "
t . string " encrypted_value_salt "
t . string " encrypted_value_iv "
t . integer " pipeline_id " , null : false
2019-12-16 22:33:55 +05:30
t . integer " variable_type " , limit : 2 , default : 1 , null : false
t . index [ " pipeline_id " , " key " ] , name : " index_ci_pipeline_variables_on_pipeline_id_and_key " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_pipelines " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " ref "
t . string " sha "
t . string " before_sha "
2015-09-25 12:07:36 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . boolean " tag " , default : false
t . text " yaml_errors "
2015-09-25 12:07:36 +05:30
t . datetime " committed_at "
2017-08-17 22:00:37 +05:30
t . integer " project_id "
2016-11-03 12:29:30 +05:30
t . string " status "
2016-06-02 11:05:42 +05:30
t . datetime " started_at "
t . datetime " finished_at "
2016-11-03 12:29:30 +05:30
t . integer " duration "
t . integer " user_id "
2017-08-17 22:00:37 +05:30
t . integer " lock_version "
t . integer " auto_canceled_by_id "
t . integer " pipeline_schedule_id "
2017-09-10 17:25:29 +05:30
t . integer " source "
2018-03-17 18:26:18 +05:30
t . integer " config_source "
t . boolean " protected "
t . integer " failure_reason "
2018-11-08 19:23:39 +05:30
t . integer " iid "
2019-02-15 15:39:39 +05:30
t . integer " merge_request_id "
2019-12-16 22:33:55 +05:30
t . binary " source_sha "
t . binary " target_sha "
t . bigint " external_pull_request_id "
t . index [ " auto_canceled_by_id " ] , name : " index_ci_pipelines_on_auto_canceled_by_id "
t . index [ " external_pull_request_id " ] , name : " index_ci_pipelines_on_external_pull_request_id " , where : " (external_pull_request_id IS NOT NULL) "
t . index [ " merge_request_id " ] , name : " index_ci_pipelines_on_merge_request_id " , where : " (merge_request_id IS NOT NULL) "
t . index [ " pipeline_schedule_id " ] , name : " index_ci_pipelines_on_pipeline_schedule_id "
t . index [ " project_id " , " iid " ] , name : " index_ci_pipelines_on_project_id_and_iid " , unique : true , where : " (iid IS NOT NULL) "
t . index [ " project_id " , " ref " , " id " ] , name : " index_ci_pipelines_on_project_idandrefandiddesc " , order : { id : :desc }
t . index [ " project_id " , " ref " , " status " , " id " ] , name : " index_ci_pipelines_on_project_id_and_ref_and_status_and_id "
t . index [ " project_id " , " sha " ] , name : " index_ci_pipelines_on_project_id_and_sha "
t . index [ " project_id " , " source " ] , name : " index_ci_pipelines_on_project_id_and_source "
t . index [ " project_id " , " status " , " config_source " ] , name : " index_ci_pipelines_on_project_id_and_status_and_config_source "
t . index [ " project_id " ] , name : " index_ci_pipelines_on_project_id "
t . index [ " status " ] , name : " index_ci_pipelines_on_status "
t . index [ " user_id " ] , name : " index_ci_pipelines_on_user_id "
end
create_table " ci_runner_namespaces " , id : :serial , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " runner_id "
t . integer " namespace_id "
2019-12-16 22:33:55 +05:30
t . index [ " namespace_id " ] , name : " index_ci_runner_namespaces_on_namespace_id "
t . index [ " runner_id " , " namespace_id " ] , name : " index_ci_runner_namespaces_on_runner_id_and_namespace_id " , unique : true
2018-10-15 14:42:47 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_runner_projects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " runner_id " , null : false
2015-09-25 12:07:36 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2017-08-17 22:00:37 +05:30
t . integer " project_id "
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_ci_runner_projects_on_project_id "
t . index [ " runner_id " ] , name : " index_ci_runner_projects_on_runner_id "
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_runners " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " token "
2015-09-25 12:07:36 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " description "
2015-09-25 12:07:36 +05:30
t . datetime " contacted_at "
2016-11-03 12:29:30 +05:30
t . boolean " active " , default : true , null : false
t . boolean " is_shared " , default : false
t . string " name "
t . string " version "
t . string " revision "
t . string " platform "
t . string " architecture "
t . boolean " run_untagged " , default : true , null : false
t . boolean " locked " , default : false , null : false
2018-03-17 18:26:18 +05:30
t . integer " access_level " , default : 0 , null : false
2018-03-27 19:54:05 +05:30
t . string " ip_address "
2018-05-09 12:01:36 +05:30
t . integer " maximum_timeout "
2018-11-08 19:23:39 +05:30
t . integer " runner_type " , limit : 2 , null : false
2019-02-15 15:39:39 +05:30
t . string " token_encrypted "
2019-12-16 22:33:55 +05:30
t . index [ " contacted_at " ] , name : " index_ci_runners_on_contacted_at "
t . index [ " is_shared " ] , name : " index_ci_runners_on_is_shared "
t . index [ " locked " ] , name : " index_ci_runners_on_locked "
t . index [ " runner_type " ] , name : " index_ci_runners_on_runner_type "
t . index [ " token " ] , name : " index_ci_runners_on_token "
t . index [ " token_encrypted " ] , name : " index_ci_runners_on_token_encrypted "
end
create_table " ci_sources_pipelines " , id : :serial , force : :cascade do | t |
t . integer " project_id "
t . integer " pipeline_id "
t . integer " source_project_id "
t . integer " source_job_id "
t . integer " source_pipeline_id "
t . index [ " pipeline_id " ] , name : " index_ci_sources_pipelines_on_pipeline_id "
t . index [ " project_id " ] , name : " index_ci_sources_pipelines_on_project_id "
t . index [ " source_job_id " ] , name : " index_ci_sources_pipelines_on_source_job_id "
t . index [ " source_pipeline_id " ] , name : " index_ci_sources_pipelines_on_source_pipeline_id "
t . index [ " source_project_id " ] , name : " index_ci_sources_pipelines_on_source_project_id "
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_stages " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . integer " project_id "
t . integer " pipeline_id "
t . datetime " created_at "
t . datetime " updated_at "
t . string " name "
2018-03-17 18:26:18 +05:30
t . integer " status "
t . integer " lock_version "
2018-10-15 14:42:47 +05:30
t . integer " position "
2019-12-16 22:33:55 +05:30
t . index [ " pipeline_id " , " name " ] , name : " index_ci_stages_on_pipeline_id_and_name " , unique : true
t . index [ " pipeline_id " , " position " ] , name : " index_ci_stages_on_pipeline_id_and_position "
t . index [ " pipeline_id " ] , name : " index_ci_stages_on_pipeline_id "
t . index [ " project_id " ] , name : " index_ci_stages_on_project_id "
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_trigger_requests " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " trigger_id " , null : false
t . text " variables "
2015-09-25 12:07:36 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " commit_id "
2019-12-16 22:33:55 +05:30
t . index [ " commit_id " ] , name : " index_ci_trigger_requests_on_commit_id "
t . index [ " trigger_id " ] , name : " index_ci_trigger_requests_on_trigger_id "
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_triggers " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " token "
2015-09-25 12:07:36 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2017-08-17 22:00:37 +05:30
t . integer " project_id "
t . integer " owner_id "
t . string " description "
t . string " ref "
2019-12-16 22:33:55 +05:30
t . index [ " owner_id " ] , name : " index_ci_triggers_on_owner_id "
t . index [ " project_id " ] , name : " index_ci_triggers_on_project_id "
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " ci_variables " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " key " , null : false
2016-11-03 12:29:30 +05:30
t . text " value "
t . text " encrypted_value "
t . string " encrypted_value_salt "
t . string " encrypted_value_iv "
2017-09-10 17:25:29 +05:30
t . integer " project_id " , null : false
t . boolean " protected " , default : false , null : false
t . string " environment_scope " , default : " * " , null : false
2019-12-16 22:33:55 +05:30
t . boolean " masked " , default : false , null : false
t . integer " variable_type " , limit : 2 , default : 1 , null : false
t . index [ " project_id " , " key " , " environment_scope " ] , name : " index_ci_variables_on_project_id_and_key_and_environment_scope " , unique : true
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " cluster_groups " , id : :serial , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . integer " cluster_id " , null : false
t . integer " group_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " , " group_id " ] , name : " index_cluster_groups_on_cluster_id_and_group_id " , unique : true
t . index [ " group_id " ] , name : " index_cluster_groups_on_group_id "
2018-12-13 13:39:08 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " cluster_platforms_kubernetes " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " cluster_id " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . text " api_url "
t . text " ca_cert "
t . string " namespace "
t . string " username "
t . text " encrypted_password "
t . string " encrypted_password_iv "
t . text " encrypted_token "
t . string " encrypted_token_iv "
2018-11-20 20:47:30 +05:30
t . integer " authorization_type " , limit : 2
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " ] , name : " index_cluster_platforms_kubernetes_on_cluster_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " cluster_projects " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
t . integer " cluster_id " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . index [ " cluster_id " ] , name : " index_cluster_projects_on_cluster_id "
t . index [ " project_id " ] , name : " index_cluster_projects_on_project_id "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " cluster_providers_gcp " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " cluster_id " , null : false
t . integer " status "
t . integer " num_nodes " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . text " status_reason "
t . string " gcp_project_id " , null : false
t . string " zone " , null : false
t . string " machine_type "
t . string " operation_id "
t . string " endpoint "
t . text " encrypted_access_token "
t . string " encrypted_access_token_iv "
2019-02-15 15:39:39 +05:30
t . boolean " legacy_abac " , default : false , null : false
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " ] , name : " index_cluster_providers_gcp_on_cluster_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " user_id "
t . integer " provider_type "
t . integer " platform_type "
2019-12-16 22:33:55 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . boolean " enabled " , default : true
t . string " name " , null : false
t . string " environment_scope " , default : " * " , null : false
2018-12-13 13:39:08 +05:30
t . integer " cluster_type " , limit : 2 , default : 3 , null : false
2019-03-02 22:35:43 +05:30
t . string " domain "
2019-12-16 22:33:55 +05:30
t . boolean " managed " , default : true , null : false
t . boolean " namespace_per_environment " , default : true , null : false
t . index [ " enabled " ] , name : " index_clusters_on_enabled "
t . index [ " user_id " ] , name : " index_clusters_on_user_id "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_cert_managers " , id : :serial , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . integer " cluster_id " , null : false
t . integer " status " , null : false
t . string " version " , null : false
t . string " email " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . text " status_reason "
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " ] , name : " index_clusters_applications_cert_managers_on_cluster_id " , unique : true
2019-02-15 15:39:39 +05:30
end
2018-03-17 18:26:18 +05:30
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_helm " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " cluster_id " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . integer " status " , null : false
t . string " version " , null : false
t . text " status_reason "
2018-11-18 11:00:15 +05:30
t . text " encrypted_ca_key "
t . text " encrypted_ca_key_iv "
t . text " ca_cert "
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " ] , name : " index_clusters_applications_helm_on_cluster_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_ingress " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " cluster_id " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . integer " status " , null : false
t . integer " ingress_type " , null : false
t . string " version " , null : false
t . string " cluster_ip "
t . text " status_reason "
2018-03-27 19:54:05 +05:30
t . string " external_ip "
2019-12-16 22:33:55 +05:30
t . string " external_hostname "
t . index [ " cluster_id " ] , name : " index_clusters_applications_ingress_on_cluster_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_jupyter " , id : :serial , force : :cascade do | t |
2018-11-08 19:23:39 +05:30
t . integer " cluster_id " , null : false
t . integer " oauth_application_id "
t . integer " status " , null : false
t . string " version " , null : false
t . string " hostname "
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . text " status_reason "
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " ] , name : " index_clusters_applications_jupyter_on_cluster_id " , unique : true
t . index [ " oauth_application_id " ] , name : " index_clusters_applications_jupyter_on_oauth_application_id "
2018-11-08 19:23:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_knative " , id : :serial , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . integer " cluster_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " status " , null : false
t . string " version " , null : false
t . string " hostname "
t . text " status_reason "
2019-02-15 15:39:39 +05:30
t . string " external_ip "
2019-12-16 22:33:55 +05:30
t . string " external_hostname "
t . index [ " cluster_id " ] , name : " index_clusters_applications_knative_on_cluster_id " , unique : true
2018-12-13 13:39:08 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_prometheus " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " cluster_id " , null : false
t . integer " status " , null : false
t . string " version " , null : false
t . text " status_reason "
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . datetime_with_timezone " last_update_started_at "
t . string " encrypted_alert_manager_token "
t . string " encrypted_alert_manager_token_iv "
t . index [ " cluster_id " ] , name : " index_clusters_applications_prometheus_on_cluster_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_applications_runners " , id : :serial , force : :cascade do | t |
2018-03-27 19:54:05 +05:30
t . integer " cluster_id " , null : false
t . integer " runner_id "
t . integer " status " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " version " , null : false
t . text " status_reason "
t . boolean " privileged " , default : true , null : false
2019-12-16 22:33:55 +05:30
t . index [ " cluster_id " ] , name : " index_clusters_applications_runners_on_cluster_id " , unique : true
t . index [ " runner_id " ] , name : " index_clusters_applications_runners_on_runner_id "
2018-03-27 19:54:05 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " clusters_kubernetes_namespaces " , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . integer " cluster_id " , null : false
t . integer " project_id "
t . integer " cluster_project_id "
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . text " encrypted_service_account_token "
t . string " encrypted_service_account_token_iv "
t . string " namespace " , null : false
t . string " service_account_name "
2019-12-16 22:33:55 +05:30
t . bigint " environment_id "
t . index [ " cluster_id " , " namespace " ] , name : " kubernetes_namespaces_cluster_and_namespace " , unique : true
t . index [ " cluster_id " , " project_id " , " environment_id " ] , name : " index_kubernetes_namespaces_on_cluster_project_environment_id " , unique : true
t . index [ " cluster_id " ] , name : " index_clusters_kubernetes_namespaces_on_cluster_id "
t . index [ " cluster_project_id " ] , name : " index_clusters_kubernetes_namespaces_on_cluster_project_id "
t . index [ " environment_id " ] , name : " index_clusters_kubernetes_namespaces_on_environment_id "
t . index [ " project_id " ] , name : " index_clusters_kubernetes_namespaces_on_project_id "
2018-12-13 13:39:08 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " container_repositories " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " project_id " , null : false
t . string " name " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " , " name " ] , name : " index_container_repositories_on_project_id_and_name " , unique : true
t . index [ " project_id " ] , name : " index_container_repositories_on_project_id "
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " conversational_development_index_metrics " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . float " leader_issues " , null : false
t . float " instance_issues " , null : false
t . float " leader_notes " , null : false
t . float " instance_notes " , null : false
t . float " leader_milestones " , null : false
t . float " instance_milestones " , null : false
t . float " leader_boards " , null : false
t . float " instance_boards " , null : false
t . float " leader_merge_requests " , null : false
t . float " instance_merge_requests " , null : false
t . float " leader_ci_pipelines " , null : false
t . float " instance_ci_pipelines " , null : false
t . float " leader_environments " , null : false
t . float " instance_environments " , null : false
t . float " leader_deployments " , null : false
t . float " instance_deployments " , null : false
t . float " leader_projects_prometheus_active " , null : false
t . float " instance_projects_prometheus_active " , null : false
t . float " leader_service_desk_issues " , null : false
t . float " instance_service_desk_issues " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . float " percentage_boards " , default : 0 . 0 , null : false
t . float " percentage_ci_pipelines " , default : 0 . 0 , null : false
t . float " percentage_deployments " , default : 0 . 0 , null : false
t . float " percentage_environments " , default : 0 . 0 , null : false
t . float " percentage_issues " , default : 0 . 0 , null : false
t . float " percentage_merge_requests " , default : 0 . 0 , null : false
t . float " percentage_milestones " , default : 0 . 0 , null : false
t . float " percentage_notes " , default : 0 . 0 , null : false
t . float " percentage_projects_prometheus_active " , default : 0 . 0 , null : false
t . float " percentage_service_desk_issues " , default : 0 . 0 , null : false
end
2019-12-16 22:33:55 +05:30
create_table " dependency_proxy_blobs " , id : :serial , force : :cascade do | t |
t . integer " group_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . bigint " size "
t . integer " file_store "
t . string " file_name " , null : false
t . text " file " , null : false
t . index [ " group_id " , " file_name " ] , name : " index_dependency_proxy_blobs_on_group_id_and_file_name "
end
create_table " dependency_proxy_group_settings " , id : :serial , force : :cascade do | t |
t . integer " group_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . boolean " enabled " , default : false , null : false
t . index [ " group_id " ] , name : " index_dependency_proxy_group_settings_on_group_id "
end
create_table " deploy_keys_projects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " deploy_key_id " , null : false
t . integer " project_id " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2018-03-17 18:26:18 +05:30
t . boolean " can_push " , default : false , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_deploy_keys_projects_on_project_id "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " deploy_tokens " , id : :serial , force : :cascade do | t |
2018-05-09 12:01:36 +05:30
t . boolean " revoked " , default : false
t . boolean " read_repository " , default : false , null : false
t . boolean " read_registry " , default : false , null : false
t . datetime_with_timezone " expires_at " , null : false
t . datetime_with_timezone " created_at " , null : false
t . string " name " , null : false
2019-12-16 22:33:55 +05:30
t . string " token "
t . string " username "
t . string " token_encrypted " , limit : 255
t . index [ " token " , " expires_at " , " id " ] , name : " index_deploy_tokens_on_token_and_expires_at_and_id " , where : " (revoked IS FALSE) "
t . index [ " token " ] , name : " index_deploy_tokens_on_token " , unique : true
t . index [ " token_encrypted " ] , name : " index_deploy_tokens_on_token_encrypted " , unique : true
2018-05-09 12:01:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " deployments " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " iid " , null : false
t . integer " project_id " , null : false
t . integer " environment_id " , null : false
t . string " ref " , null : false
t . boolean " tag " , null : false
t . string " sha " , null : false
t . integer " user_id "
t . integer " deployable_id "
t . string " deployable_type "
2016-06-16 23:09:34 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " on_stop "
2019-02-15 15:39:39 +05:30
t . integer " status " , limit : 2 , null : false
2018-12-13 13:39:08 +05:30
t . datetime_with_timezone " finished_at "
2019-12-16 22:33:55 +05:30
t . integer " cluster_id "
t . index [ " cluster_id " , " status " ] , name : " index_deployments_on_cluster_id_and_status "
t . index [ " created_at " ] , name : " index_deployments_on_created_at "
t . index [ " deployable_type " , " deployable_id " ] , name : " index_deployments_on_deployable_type_and_deployable_id "
t . index [ " environment_id " , " id " ] , name : " index_deployments_on_environment_id_and_id "
t . index [ " environment_id " , " iid " , " project_id " ] , name : " index_deployments_on_environment_id_and_iid_and_project_id "
t . index [ " environment_id " , " status " ] , name : " index_deployments_on_environment_id_and_status "
t . index [ " id " ] , name : " partial_index_deployments_for_legacy_successful_deployments " , where : " ((finished_at IS NULL) AND (status = 2)) "
t . index [ " project_id " , " iid " ] , name : " index_deployments_on_project_id_and_iid " , unique : true
t . index [ " project_id " , " status " , " created_at " ] , name : " index_deployments_on_project_id_and_status_and_created_at "
t . index [ " project_id " , " status " ] , name : " index_deployments_on_project_id_and_status "
end
create_table " design_management_designs " , force : :cascade do | t |
t . integer " project_id " , null : false
t . integer " issue_id " , null : false
t . string " filename " , null : false
t . index [ " issue_id " , " filename " ] , name : " index_design_management_designs_on_issue_id_and_filename " , unique : true
t . index [ " project_id " ] , name : " index_design_management_designs_on_project_id "
end
create_table " design_management_designs_versions " , id : false , force : :cascade do | t |
t . bigint " design_id " , null : false
t . bigint " version_id " , null : false
t . integer " event " , limit : 2 , default : 0 , null : false
t . index [ " design_id " , " version_id " ] , name : " design_management_designs_versions_uniqueness " , unique : true
t . index [ " design_id " ] , name : " index_design_management_designs_versions_on_design_id "
t . index [ " event " ] , name : " index_design_management_designs_versions_on_event "
t . index [ " version_id " ] , name : " index_design_management_designs_versions_on_version_id "
end
create_table " design_management_versions " , force : :cascade do | t |
t . binary " sha " , null : false
t . bigint " issue_id "
t . index [ " issue_id " ] , name : " index_design_management_versions_on_issue_id "
t . index [ " sha " , " issue_id " ] , name : " index_design_management_versions_on_sha_and_issue_id " , unique : true
end
create_table " draft_notes " , force : :cascade do | t |
t . integer " merge_request_id " , null : false
t . integer " author_id " , null : false
t . boolean " resolve_discussion " , default : false , null : false
t . string " discussion_id "
t . text " note " , null : false
t . text " position "
t . text " original_position "
t . text " change_position "
t . binary " commit_id "
t . index [ " author_id " ] , name : " index_draft_notes_on_author_id "
t . index [ " discussion_id " ] , name : " index_draft_notes_on_discussion_id "
t . index [ " merge_request_id " ] , name : " index_draft_notes_on_merge_request_id "
end
create_table " elasticsearch_indexed_namespaces " , id : false , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " namespace_id "
t . index [ " namespace_id " ] , name : " index_elasticsearch_indexed_namespaces_on_namespace_id " , unique : true
end
create_table " elasticsearch_indexed_projects " , id : false , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " project_id "
t . index [ " project_id " ] , name : " index_elasticsearch_indexed_projects_on_project_id " , unique : true
end
create_table " emails " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id " , null : false
t . string " email " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2018-03-17 18:26:18 +05:30
t . string " confirmation_token "
2019-12-16 22:33:55 +05:30
t . datetime " confirmed_at "
t . datetime " confirmation_sent_at "
t . index [ " confirmation_token " ] , name : " index_emails_on_confirmation_token " , unique : true
t . index [ " email " ] , name : " index_emails_on_email " , unique : true
t . index [ " user_id " ] , name : " index_emails_on_user_id "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " environments " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
2016-11-03 12:29:30 +05:30
t . string " name " , null : false
2016-06-16 23:09:34 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " external_url "
t . string " environment_type "
t . string " state " , default : " available " , null : false
2017-08-17 22:00:37 +05:30
t . string " slug " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " name " ] , name : " index_environments_on_name_varchar_pattern_ops " , opclass : :varchar_pattern_ops
t . index [ " project_id " , " name " ] , name : " index_environments_on_project_id_and_name " , unique : true
t . index [ " project_id " , " slug " ] , name : " index_environments_on_project_id_and_slug " , unique : true
t . index [ " project_id " , " state " ] , name : " index_environments_on_project_id_and_state "
end
create_table " epic_issues " , id : :serial , force : :cascade do | t |
t . integer " epic_id " , null : false
t . integer " issue_id " , null : false
t . integer " relative_position "
t . index [ " epic_id " ] , name : " index_epic_issues_on_epic_id "
t . index [ " issue_id " ] , name : " index_epic_issues_on_issue_id " , unique : true
end
create_table " epic_metrics " , id : :serial , force : :cascade do | t |
t . integer " epic_id " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . index [ " epic_id " ] , name : " index_epic_metrics "
2016-06-16 23:09:34 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " epics " , id : :serial , force : :cascade do | t |
t . integer " milestone_id "
t . integer " group_id " , null : false
t . integer " author_id " , null : false
t . integer " assignee_id "
t . integer " iid " , null : false
t . integer " cached_markdown_version "
t . integer " updated_by_id "
t . integer " last_edited_by_id "
t . integer " lock_version "
t . date " start_date "
t . date " end_date "
t . datetime " last_edited_at "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . string " title " , null : false
t . string " title_html " , null : false
t . text " description "
t . text " description_html "
t . integer " start_date_sourcing_milestone_id "
t . integer " due_date_sourcing_milestone_id "
t . date " start_date_fixed "
t . date " due_date_fixed "
t . boolean " start_date_is_fixed "
t . boolean " due_date_is_fixed "
t . integer " closed_by_id "
t . datetime " closed_at "
t . integer " parent_id "
t . integer " relative_position "
t . integer " state_id " , limit : 2 , default : 1 , null : false
t . index [ " assignee_id " ] , name : " index_epics_on_assignee_id "
t . index [ " author_id " ] , name : " index_epics_on_author_id "
t . index [ " closed_by_id " ] , name : " index_epics_on_closed_by_id "
t . index [ " end_date " ] , name : " index_epics_on_end_date "
t . index [ " group_id " ] , name : " index_epics_on_group_id "
t . index [ " iid " ] , name : " index_epics_on_iid "
t . index [ " milestone_id " ] , name : " index_milestone "
t . index [ " parent_id " ] , name : " index_epics_on_parent_id "
t . index [ " start_date " ] , name : " index_epics_on_start_date "
end
create_table " events " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . integer " project_id "
t . integer " author_id " , null : false
t . integer " target_id "
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2017-09-10 17:25:29 +05:30
t . integer " action " , limit : 2 , null : false
t . string " target_type "
2019-12-16 22:33:55 +05:30
t . bigint " group_id "
t . index [ " action " ] , name : " index_events_on_action "
t . index [ " author_id " , " project_id " ] , name : " index_events_on_author_id_and_project_id "
t . index [ " created_at " , " author_id " ] , name : " analytics_index_events_on_created_at_and_author_id "
t . index [ " group_id " ] , name : " index_events_on_group_id_partial " , where : " (group_id IS NOT NULL) "
t . index [ " project_id " , " created_at " ] , name : " index_events_on_project_id_and_created_at "
t . index [ " project_id " , " id " ] , name : " index_events_on_project_id_and_id "
t . index [ " target_type " , " target_id " ] , name : " index_events_on_target_type_and_target_id "
end
create_table " external_pull_requests " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . bigint " project_id " , null : false
t . integer " pull_request_iid " , null : false
t . integer " status " , limit : 2 , null : false
t . string " source_branch " , limit : 255 , null : false
t . string " target_branch " , limit : 255 , null : false
t . string " source_repository " , limit : 255 , null : false
t . string " target_repository " , limit : 255 , null : false
t . binary " source_sha " , null : false
t . binary " target_sha " , null : false
t . index [ " project_id " , " source_branch " , " target_branch " ] , name : " index_external_pull_requests_on_project_and_branches " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " feature_gates " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " feature_key " , null : false
t . string " key " , null : false
t . string " value "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " feature_key " , " key " , " value " ] , name : " index_feature_gates_on_feature_key_and_key_and_value " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " features " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . string " key " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " key " ] , name : " index_features_on_key " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " fork_network_members " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " fork_network_id " , null : false
t . integer " project_id " , null : false
t . integer " forked_from_project_id "
2019-12-16 22:33:55 +05:30
t . index [ " fork_network_id " ] , name : " index_fork_network_members_on_fork_network_id "
t . index [ " forked_from_project_id " ] , name : " index_fork_network_members_on_forked_from_project_id "
t . index [ " project_id " ] , name : " index_fork_network_members_on_project_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " fork_networks " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " root_project_id "
t . string " deleted_root_project_name "
2019-12-16 22:33:55 +05:30
t . index [ " root_project_id " ] , name : " index_fork_networks_on_root_project_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " forked_project_links " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " forked_to_project_id " , null : false
t . integer " forked_from_project_id " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . index [ " forked_to_project_id " ] , name : " index_forked_project_links_on_forked_to_project_id " , unique : true
end
create_table " geo_cache_invalidation_events " , force : :cascade do | t |
t . string " key " , null : false
end
create_table " geo_container_repository_updated_events " , force : :cascade do | t |
t . integer " container_repository_id " , null : false
t . index [ " container_repository_id " ] , name : " idx_geo_con_rep_updated_events_on_container_repository_id "
end
create_table " geo_event_log " , force : :cascade do | t |
t . datetime " created_at " , null : false
t . bigint " repository_updated_event_id "
t . bigint " repository_deleted_event_id "
t . bigint " repository_renamed_event_id "
t . bigint " repositories_changed_event_id "
t . bigint " repository_created_event_id "
t . bigint " hashed_storage_migrated_event_id "
t . bigint " lfs_object_deleted_event_id "
t . bigint " hashed_storage_attachments_event_id "
t . bigint " upload_deleted_event_id "
t . bigint " job_artifact_deleted_event_id "
t . bigint " reset_checksum_event_id "
t . bigint " cache_invalidation_event_id "
t . bigint " container_repository_updated_event_id "
t . index [ " cache_invalidation_event_id " ] , name : " index_geo_event_log_on_cache_invalidation_event_id " , where : " (cache_invalidation_event_id IS NOT NULL) "
t . index [ " container_repository_updated_event_id " ] , name : " index_geo_event_log_on_container_repository_updated_event_id "
t . index [ " hashed_storage_attachments_event_id " ] , name : " index_geo_event_log_on_hashed_storage_attachments_event_id " , where : " (hashed_storage_attachments_event_id IS NOT NULL) "
t . index [ " hashed_storage_migrated_event_id " ] , name : " index_geo_event_log_on_hashed_storage_migrated_event_id " , where : " (hashed_storage_migrated_event_id IS NOT NULL) "
t . index [ " job_artifact_deleted_event_id " ] , name : " index_geo_event_log_on_job_artifact_deleted_event_id " , where : " (job_artifact_deleted_event_id IS NOT NULL) "
t . index [ " lfs_object_deleted_event_id " ] , name : " index_geo_event_log_on_lfs_object_deleted_event_id " , where : " (lfs_object_deleted_event_id IS NOT NULL) "
t . index [ " repositories_changed_event_id " ] , name : " index_geo_event_log_on_repositories_changed_event_id " , where : " (repositories_changed_event_id IS NOT NULL) "
t . index [ " repository_created_event_id " ] , name : " index_geo_event_log_on_repository_created_event_id " , where : " (repository_created_event_id IS NOT NULL) "
t . index [ " repository_deleted_event_id " ] , name : " index_geo_event_log_on_repository_deleted_event_id " , where : " (repository_deleted_event_id IS NOT NULL) "
t . index [ " repository_renamed_event_id " ] , name : " index_geo_event_log_on_repository_renamed_event_id " , where : " (repository_renamed_event_id IS NOT NULL) "
t . index [ " repository_updated_event_id " ] , name : " index_geo_event_log_on_repository_updated_event_id " , where : " (repository_updated_event_id IS NOT NULL) "
t . index [ " reset_checksum_event_id " ] , name : " index_geo_event_log_on_reset_checksum_event_id " , where : " (reset_checksum_event_id IS NOT NULL) "
t . index [ " upload_deleted_event_id " ] , name : " index_geo_event_log_on_upload_deleted_event_id " , where : " (upload_deleted_event_id IS NOT NULL) "
end
create_table " geo_hashed_storage_attachments_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . text " old_attachments_path " , null : false
t . text " new_attachments_path " , null : false
t . index [ " project_id " ] , name : " index_geo_hashed_storage_attachments_events_on_project_id "
end
create_table " geo_hashed_storage_migrated_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . text " repository_storage_name " , null : false
t . text " old_disk_path " , null : false
t . text " new_disk_path " , null : false
t . text " old_wiki_disk_path " , null : false
t . text " new_wiki_disk_path " , null : false
t . integer " old_storage_version " , limit : 2
t . integer " new_storage_version " , limit : 2 , null : false
t . index [ " project_id " ] , name : " index_geo_hashed_storage_migrated_events_on_project_id "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " geo_job_artifact_deleted_events " , force : :cascade do | t |
t . integer " job_artifact_id " , null : false
t . string " file_path " , null : false
t . index [ " job_artifact_id " ] , name : " index_geo_job_artifact_deleted_events_on_job_artifact_id "
end
create_table " geo_lfs_object_deleted_events " , force : :cascade do | t |
t . integer " lfs_object_id " , null : false
t . string " oid " , null : false
t . string " file_path " , null : false
t . index [ " lfs_object_id " ] , name : " index_geo_lfs_object_deleted_events_on_lfs_object_id "
end
create_table " geo_node_namespace_links " , id : :serial , force : :cascade do | t |
t . integer " geo_node_id " , null : false
t . integer " namespace_id " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . index [ " geo_node_id " , " namespace_id " ] , name : " index_geo_node_namespace_links_on_geo_node_id_and_namespace_id " , unique : true
t . index [ " geo_node_id " ] , name : " index_geo_node_namespace_links_on_geo_node_id "
t . index [ " namespace_id " ] , name : " index_geo_node_namespace_links_on_namespace_id "
end
create_table " geo_node_statuses " , id : :serial , force : :cascade do | t |
t . integer " geo_node_id " , null : false
t . integer " db_replication_lag_seconds "
t . integer " repositories_synced_count "
t . integer " repositories_failed_count "
t . integer " lfs_objects_count "
t . integer " lfs_objects_synced_count "
t . integer " lfs_objects_failed_count "
t . integer " attachments_count "
t . integer " attachments_synced_count "
t . integer " attachments_failed_count "
t . integer " last_event_id "
t . datetime " last_event_date "
t . integer " cursor_last_event_id "
t . datetime " cursor_last_event_date "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . datetime " last_successful_status_check_at "
t . string " status_message "
t . integer " replication_slots_count "
t . integer " replication_slots_used_count "
t . bigint " replication_slots_max_retained_wal_bytes "
t . integer " wikis_synced_count "
t . integer " wikis_failed_count "
t . integer " job_artifacts_count "
t . integer " job_artifacts_synced_count "
t . integer " job_artifacts_failed_count "
t . string " version "
t . string " revision "
t . integer " repositories_verified_count "
t . integer " repositories_verification_failed_count "
t . integer " wikis_verified_count "
t . integer " wikis_verification_failed_count "
t . integer " lfs_objects_synced_missing_on_primary_count "
t . integer " job_artifacts_synced_missing_on_primary_count "
t . integer " attachments_synced_missing_on_primary_count "
t . integer " repositories_checksummed_count "
t . integer " repositories_checksum_failed_count "
t . integer " repositories_checksum_mismatch_count "
t . integer " wikis_checksummed_count "
t . integer " wikis_checksum_failed_count "
t . integer " wikis_checksum_mismatch_count "
t . binary " storage_configuration_digest "
t . integer " repositories_retrying_verification_count "
t . integer " wikis_retrying_verification_count "
t . integer " projects_count "
t . integer " container_repositories_count "
t . integer " container_repositories_synced_count "
t . integer " container_repositories_failed_count "
t . integer " container_repositories_registry_count "
t . index [ " geo_node_id " ] , name : " index_geo_node_statuses_on_geo_node_id " , unique : true
end
create_table " geo_nodes " , id : :serial , force : :cascade do | t |
t . boolean " primary " , default : false , null : false
t . integer " oauth_application_id "
t . boolean " enabled " , default : true , null : false
t . string " access_key "
t . string " encrypted_secret_access_key "
t . string " encrypted_secret_access_key_iv "
t . string " clone_url_prefix "
t . integer " files_max_capacity " , default : 10 , null : false
t . integer " repos_max_capacity " , default : 25 , null : false
t . string " url " , null : false
t . string " selective_sync_type "
t . text " selective_sync_shards "
t . integer " verification_max_capacity " , default : 100 , null : false
t . integer " minimum_reverification_interval " , default : 7 , null : false
t . string " internal_url "
t . string " name " , null : false
t . integer " container_repositories_max_capacity " , default : 10 , null : false
t . datetime_with_timezone " created_at "
t . datetime_with_timezone " updated_at "
t . boolean " sync_object_storage " , default : false , null : false
t . index [ " access_key " ] , name : " index_geo_nodes_on_access_key "
t . index [ " name " ] , name : " index_geo_nodes_on_name " , unique : true
t . index [ " primary " ] , name : " index_geo_nodes_on_primary "
end
create_table " geo_repositories_changed_events " , force : :cascade do | t |
t . integer " geo_node_id " , null : false
t . index [ " geo_node_id " ] , name : " index_geo_repositories_changed_events_on_geo_node_id "
end
create_table " geo_repository_created_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . text " repository_storage_name " , null : false
t . text " repo_path " , null : false
t . text " wiki_path "
t . text " project_name " , null : false
t . index [ " project_id " ] , name : " index_geo_repository_created_events_on_project_id "
end
create_table " geo_repository_deleted_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . text " repository_storage_name " , null : false
t . text " deleted_path " , null : false
t . text " deleted_wiki_path "
t . text " deleted_project_name " , null : false
t . index [ " project_id " ] , name : " index_geo_repository_deleted_events_on_project_id "
end
create_table " geo_repository_renamed_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . text " repository_storage_name " , null : false
t . text " old_path_with_namespace " , null : false
t . text " new_path_with_namespace " , null : false
t . text " old_wiki_path_with_namespace " , null : false
t . text " new_wiki_path_with_namespace " , null : false
t . text " old_path " , null : false
t . text " new_path " , null : false
t . index [ " project_id " ] , name : " index_geo_repository_renamed_events_on_project_id "
end
create_table " geo_repository_updated_events " , force : :cascade do | t |
t . integer " branches_affected " , null : false
t . integer " tags_affected " , null : false
t . integer " project_id " , null : false
t . integer " source " , limit : 2 , null : false
t . boolean " new_branch " , default : false , null : false
t . boolean " remove_branch " , default : false , null : false
t . text " ref "
t . index [ " project_id " ] , name : " index_geo_repository_updated_events_on_project_id "
t . index [ " source " ] , name : " index_geo_repository_updated_events_on_source "
end
create_table " geo_reset_checksum_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . index [ " project_id " ] , name : " index_geo_reset_checksum_events_on_project_id "
end
create_table " geo_upload_deleted_events " , force : :cascade do | t |
t . integer " upload_id " , null : false
t . string " file_path " , null : false
t . integer " model_id " , null : false
t . string " model_type " , null : false
t . string " uploader " , null : false
t . index [ " upload_id " ] , name : " index_geo_upload_deleted_events_on_upload_id "
end
create_table " gitlab_subscriptions " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . date " start_date "
t . date " end_date "
t . date " trial_ends_on "
t . integer " namespace_id "
t . integer " hosted_plan_id "
t . integer " max_seats_used " , default : 0
t . integer " seats " , default : 0
t . boolean " trial " , default : false
t . index [ " hosted_plan_id " ] , name : " index_gitlab_subscriptions_on_hosted_plan_id "
t . index [ " namespace_id " ] , name : " index_gitlab_subscriptions_on_namespace_id " , unique : true
end
create_table " gpg_key_subkeys " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " gpg_key_id " , null : false
t . binary " keyid "
t . binary " fingerprint "
2019-12-16 22:33:55 +05:30
t . index [ " fingerprint " ] , name : " index_gpg_key_subkeys_on_fingerprint " , unique : true
t . index [ " gpg_key_id " ] , name : " index_gpg_key_subkeys_on_gpg_key_id "
t . index [ " keyid " ] , name : " index_gpg_key_subkeys_on_keyid " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " gpg_keys " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2017-09-10 17:25:29 +05:30
t . integer " user_id "
t . binary " primary_keyid "
t . binary " fingerprint "
t . text " key "
2019-12-16 22:33:55 +05:30
t . index [ " fingerprint " ] , name : " index_gpg_keys_on_fingerprint " , unique : true
t . index [ " primary_keyid " ] , name : " index_gpg_keys_on_primary_keyid " , unique : true
t . index [ " user_id " ] , name : " index_gpg_keys_on_user_id "
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " gpg_signatures " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2017-09-10 17:25:29 +05:30
t . integer " project_id "
t . integer " gpg_key_id "
t . binary " commit_sha "
t . binary " gpg_key_primary_keyid "
t . text " gpg_key_user_name "
t . text " gpg_key_user_email "
2018-03-17 18:26:18 +05:30
t . integer " verification_status " , limit : 2 , default : 0 , null : false
t . integer " gpg_key_subkey_id "
2019-12-16 22:33:55 +05:30
t . index [ " commit_sha " ] , name : " index_gpg_signatures_on_commit_sha " , unique : true
t . index [ " gpg_key_id " ] , name : " index_gpg_signatures_on_gpg_key_id "
t . index [ " gpg_key_primary_keyid " ] , name : " index_gpg_signatures_on_gpg_key_primary_keyid "
t . index [ " gpg_key_subkey_id " ] , name : " index_gpg_signatures_on_gpg_key_subkey_id "
t . index [ " project_id " ] , name : " index_gpg_signatures_on_project_id "
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " group_custom_attributes " , id : :serial , force : :cascade do | t |
2018-12-05 23:21:45 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . integer " group_id " , null : false
t . string " key " , null : false
t . string " value " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " group_id " , " key " ] , name : " index_group_custom_attributes_on_group_id_and_key " , unique : true
t . index [ " key " , " value " ] , name : " index_group_custom_attributes_on_key_and_value "
end
create_table " historical_data " , id : :serial , force : :cascade do | t |
t . date " date " , null : false
t . integer " active_user_count "
t . datetime " created_at "
t . datetime " updated_at "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " identities " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " extern_uid "
t . string " provider "
t . integer " user_id "
2015-04-26 12:48:37 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . string " secondary_extern_uid "
t . integer " saml_provider_id "
t . index " lower((extern_uid)::text), provider " , name : " index_on_identities_lower_extern_uid_and_provider "
t . index [ " saml_provider_id " ] , name : " index_identities_on_saml_provider_id " , where : " (saml_provider_id IS NOT NULL) "
t . index [ " user_id " ] , name : " index_identities_on_user_id "
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " import_export_uploads " , id : :serial , force : :cascade do | t |
2018-11-08 19:23:39 +05:30
t . datetime_with_timezone " updated_at " , null : false
t . integer " project_id "
t . text " import_file "
t . text " export_file "
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_import_export_uploads_on_project_id "
t . index [ " updated_at " ] , name : " index_import_export_uploads_on_updated_at "
2018-11-08 19:23:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " index_statuses " , id : :serial , force : :cascade do | t |
t . integer " project_id " , null : false
t . datetime " indexed_at "
t . text " note "
t . string " last_commit "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . binary " last_wiki_commit "
t . datetime_with_timezone " wiki_indexed_at "
t . index [ " project_id " ] , name : " index_index_statuses_on_project_id " , unique : true
end
create_table " insights " , id : :serial , force : :cascade do | t |
t . integer " namespace_id " , null : false
t . integer " project_id " , null : false
t . index [ " namespace_id " ] , name : " index_insights_on_namespace_id "
t . index [ " project_id " ] , name : " index_insights_on_project_id "
end
create_table " internal_ids " , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " project_id "
2018-05-09 12:01:36 +05:30
t . integer " usage " , null : false
t . integer " last_value " , null : false
2018-10-15 14:42:47 +05:30
t . integer " namespace_id "
2019-12-16 22:33:55 +05:30
t . index [ " namespace_id " ] , name : " index_internal_ids_on_namespace_id "
t . index [ " project_id " ] , name : " index_internal_ids_on_project_id "
t . index [ " usage " , " namespace_id " ] , name : " index_internal_ids_on_usage_and_namespace_id " , unique : true , where : " (namespace_id IS NOT NULL) "
t . index [ " usage " , " project_id " ] , name : " index_internal_ids_on_usage_and_project_id " , unique : true , where : " (project_id IS NOT NULL) "
end
create_table " ip_restrictions " , force : :cascade do | t |
t . integer " group_id " , null : false
t . string " range " , null : false
t . index [ " group_id " ] , name : " index_ip_restrictions_on_group_id "
2018-05-09 12:01:36 +05:30
end
2017-08-17 22:00:37 +05:30
create_table " issue_assignees " , id : false , force : :cascade do | t |
t . integer " user_id " , null : false
t . integer " issue_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " issue_id " , " user_id " ] , name : " index_issue_assignees_on_issue_id_and_user_id " , unique : true
t . index [ " user_id " ] , name : " index_issue_assignees_on_user_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " issue_links " , id : :serial , force : :cascade do | t |
t . integer " source_id " , null : false
t . integer " target_id " , null : false
t . datetime " created_at "
t . datetime " updated_at "
t . index [ " source_id " , " target_id " ] , name : " index_issue_links_on_source_id_and_target_id " , unique : true
t . index [ " source_id " ] , name : " index_issue_links_on_source_id "
t . index [ " target_id " ] , name : " index_issue_links_on_target_id "
end
create_table " issue_metrics " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " issue_id " , null : false
2016-09-29 09:46:39 +05:30
t . datetime " first_mentioned_in_commit_at "
t . datetime " first_associated_with_milestone_at "
t . datetime " first_added_to_board_at "
2016-11-03 12:29:30 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " issue_id " ] , name : " index_issue_metrics "
end
create_table " issue_tracker_data " , force : :cascade do | t |
t . integer " service_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " encrypted_project_url "
t . string " encrypted_project_url_iv "
t . string " encrypted_issues_url "
t . string " encrypted_issues_url_iv "
t . string " encrypted_new_issue_url "
t . string " encrypted_new_issue_url_iv "
t . index [ " service_id " ] , name : " index_issue_tracker_data_on_service_id "
2016-09-29 09:46:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " issues " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " title "
t . integer " author_id "
t . integer " project_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . text " description "
t . integer " milestone_id "
t . string " state "
t . integer " iid "
t . integer " updated_by_id "
2019-12-16 22:33:55 +05:30
t . integer " weight "
2018-03-17 18:26:18 +05:30
t . boolean " confidential " , default : false , null : false
2016-11-03 12:29:30 +05:30
t . date " due_date "
t . integer " moved_to_id "
t . integer " lock_version "
t . text " title_html "
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . integer " time_estimate "
t . integer " relative_position "
2019-12-16 22:33:55 +05:30
t . string " service_desk_reply_to "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
t . datetime " last_edited_at "
t . integer " last_edited_by_id "
2018-03-17 18:26:18 +05:30
t . boolean " discussion_locked "
t . datetime_with_timezone " closed_at "
2018-05-09 12:01:36 +05:30
t . integer " closed_by_id "
2019-12-16 22:33:55 +05:30
t . integer " state_id " , limit : 2
t . integer " duplicated_to_id "
t . index [ " author_id " ] , name : " index_issues_on_author_id "
t . index [ " closed_by_id " ] , name : " index_issues_on_closed_by_id "
t . index [ " confidential " ] , name : " index_issues_on_confidential "
t . index [ " description " ] , name : " index_issues_on_description_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " duplicated_to_id " ] , name : " index_issues_on_duplicated_to_id " , where : " (duplicated_to_id IS NOT NULL) "
t . index [ " milestone_id " ] , name : " index_issues_on_milestone_id "
t . index [ " moved_to_id " ] , name : " index_issues_on_moved_to_id " , where : " (moved_to_id IS NOT NULL) "
t . index [ " project_id " , " created_at " , " id " , " state " ] , name : " index_issues_on_project_id_and_created_at_and_id_and_state "
t . index [ " project_id " , " due_date " , " id " , " state " ] , name : " idx_issues_on_project_id_and_due_date_and_id_and_state_partial " , where : " (due_date IS NOT NULL) "
t . index [ " project_id " , " iid " ] , name : " index_issues_on_project_id_and_iid " , unique : true
t . index [ " project_id " , " relative_position " , " state " , " id " ] , name : " index_issues_on_project_id_and_rel_position_and_state_and_id " , order : { id : :desc }
t . index [ " project_id " , " updated_at " , " id " , " state " ] , name : " index_issues_on_project_id_and_updated_at_and_id_and_state "
t . index [ " relative_position " ] , name : " index_issues_on_relative_position "
t . index [ " state " ] , name : " index_issues_on_state "
t . index [ " title " ] , name : " index_issues_on_title_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " updated_at " ] , name : " index_issues_on_updated_at "
t . index [ " updated_by_id " ] , name : " index_issues_on_updated_by_id " , where : " (updated_by_id IS NOT NULL) "
end
create_table " jira_connect_installations " , force : :cascade do | t |
t . string " client_key "
t . string " encrypted_shared_secret "
t . string " encrypted_shared_secret_iv "
t . string " base_url "
t . index [ " client_key " ] , name : " index_jira_connect_installations_on_client_key " , unique : true
end
create_table " jira_connect_subscriptions " , force : :cascade do | t |
t . bigint " jira_connect_installation_id " , null : false
t . integer " namespace_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . index [ " jira_connect_installation_id " , " namespace_id " ] , name : " idx_jira_connect_subscriptions_on_installation_id_namespace_id " , unique : true
t . index [ " jira_connect_installation_id " ] , name : " idx_jira_connect_subscriptions_on_installation_id "
t . index [ " namespace_id " ] , name : " index_jira_connect_subscriptions_on_namespace_id "
end
create_table " jira_tracker_data " , force : :cascade do | t |
t . integer " service_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " encrypted_url "
t . string " encrypted_url_iv "
t . string " encrypted_api_url "
t . string " encrypted_api_url_iv "
t . string " encrypted_username "
t . string " encrypted_username_iv "
t . string " encrypted_password "
t . string " encrypted_password_iv "
t . string " jira_issue_transition_id "
t . index [ " service_id " ] , name : " index_jira_tracker_data_on_service_id "
end
create_table " keys " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . text " key "
t . string " title "
t . string " type "
t . string " fingerprint "
t . boolean " public " , default : false , null : false
2017-08-17 22:00:37 +05:30
t . datetime " last_used_at "
2019-12-16 22:33:55 +05:30
t . index [ " fingerprint " ] , name : " index_keys_on_fingerprint " , unique : true
t . index [ " id " , " type " ] , name : " index_on_deploy_keys_id_and_type_and_public " , unique : true , where : " (public = true) "
t . index [ " user_id " ] , name : " index_keys_on_user_id "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " label_links " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " label_id "
t . integer " target_id "
t . string " target_type "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . index [ " label_id " ] , name : " index_label_links_on_label_id "
t . index [ " target_id " , " target_type " ] , name : " index_label_links_on_target_id_and_target_type "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " label_priorities " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " project_id " , null : false
t . integer " label_id " , null : false
t . integer " priority " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " label_id " ] , name : " index_label_priorities_on_label_id "
t . index [ " priority " ] , name : " index_label_priorities_on_priority "
t . index [ " project_id " , " label_id " ] , name : " index_label_priorities_on_project_id_and_label_id " , unique : true
2016-11-03 12:29:30 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " labels " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " title "
t . string " color "
t . integer " project_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . boolean " template " , default : false
t . string " description "
t . text " description_html "
t . string " type "
t . integer " group_id "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2019-12-16 22:33:55 +05:30
t . index [ " group_id " , " project_id " , " title " ] , name : " index_labels_on_group_id_and_project_id_and_title " , unique : true
t . index [ " project_id " ] , name : " index_labels_on_project_id "
t . index [ " template " ] , name : " index_labels_on_template " , where : " template "
t . index [ " title " ] , name : " index_labels_on_title "
t . index [ " type " , " project_id " ] , name : " index_labels_on_type_and_project_id "
end
create_table " ldap_group_links " , id : :serial , force : :cascade do | t |
t . string " cn "
t . integer " group_access " , null : false
t . integer " group_id " , null : false
t . datetime " created_at "
t . datetime " updated_at "
t . string " provider "
t . string " filter "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " lfs_file_locks " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
t . integer " user_id " , null : false
t . datetime " created_at " , null : false
t . string " path " , limit : 511
2019-12-16 22:33:55 +05:30
t . index [ " project_id " , " path " ] , name : " index_lfs_file_locks_on_project_id_and_path " , unique : true
t . index [ " user_id " ] , name : " index_lfs_file_locks_on_user_id "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " lfs_objects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " oid " , null : false
2019-02-15 15:39:39 +05:30
t . bigint " size " , null : false
2015-11-26 14:37:03 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " file "
2018-05-09 12:01:36 +05:30
t . integer " file_store "
2019-12-16 22:33:55 +05:30
t . index [ " file_store " ] , name : " index_lfs_objects_on_file_store "
t . index [ " oid " ] , name : " index_lfs_objects_on_oid " , unique : true
2015-11-26 14:37:03 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " lfs_objects_projects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " lfs_object_id " , null : false
t . integer " project_id " , null : false
2015-11-26 14:37:03 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . integer " repository_type " , limit : 2
t . index [ " lfs_object_id " ] , name : " index_lfs_objects_projects_on_lfs_object_id "
t . index [ " project_id " ] , name : " index_lfs_objects_projects_on_project_id "
end
create_table " licenses " , id : :serial , force : :cascade do | t |
t . text " data " , null : false
t . datetime " created_at "
t . datetime " updated_at "
end
create_table " list_user_preferences " , force : :cascade do | t |
t . bigint " user_id " , null : false
t . bigint " list_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . boolean " collapsed "
t . index [ " list_id " ] , name : " index_list_user_preferences_on_list_id "
t . index [ " user_id " , " list_id " ] , name : " index_list_user_preferences_on_user_id_and_list_id " , unique : true
t . index [ " user_id " ] , name : " index_list_user_preferences_on_user_id "
2015-11-26 14:37:03 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " lists " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " board_id " , null : false
t . integer " label_id "
t . integer " list_type " , default : 1 , null : false
t . integer " position "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . integer " user_id "
t . integer " milestone_id "
t . index [ " board_id " , " label_id " ] , name : " index_lists_on_board_id_and_label_id " , unique : true
t . index [ " label_id " ] , name : " index_lists_on_label_id "
t . index [ " list_type " ] , name : " index_lists_on_list_type "
t . index [ " milestone_id " ] , name : " index_lists_on_milestone_id "
t . index [ " user_id " ] , name : " index_lists_on_user_id "
2016-09-13 17:45:13 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " members " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " access_level " , null : false
t . integer " source_id " , null : false
t . string " source_type " , null : false
t . integer " user_id "
t . integer " notification_level " , null : false
t . string " type "
2015-04-26 12:48:37 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " created_by_id "
t . string " invite_email "
t . string " invite_token "
2015-04-26 12:48:37 +05:30
t . datetime " invite_accepted_at "
2016-06-16 23:09:34 +05:30
t . datetime " requested_at "
2016-11-03 12:29:30 +05:30
t . date " expires_at "
2019-12-16 22:33:55 +05:30
t . boolean " ldap " , default : false , null : false
t . boolean " override " , default : false , null : false
t . index [ " access_level " ] , name : " index_members_on_access_level "
t . index [ " expires_at " ] , name : " index_members_on_expires_at "
t . index [ " invite_email " ] , name : " index_members_on_invite_email "
t . index [ " invite_token " ] , name : " index_members_on_invite_token " , unique : true
t . index [ " requested_at " ] , name : " index_members_on_requested_at "
t . index [ " source_id " , " source_type " ] , name : " index_members_on_source_id_and_source_type "
t . index [ " user_id " ] , name : " index_members_on_user_id "
end
create_table " merge_request_assignees " , force : :cascade do | t |
t . integer " user_id " , null : false
t . integer " merge_request_id " , null : false
t . index [ " merge_request_id " , " user_id " ] , name : " index_merge_request_assignees_on_merge_request_id_and_user_id " , unique : true
t . index [ " merge_request_id " ] , name : " index_merge_request_assignees_on_merge_request_id "
t . index [ " user_id " ] , name : " index_merge_request_assignees_on_user_id "
end
create_table " merge_request_blocks " , force : :cascade do | t |
t . integer " blocking_merge_request_id " , null : false
t . integer " blocked_merge_request_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . index [ " blocked_merge_request_id " ] , name : " index_merge_request_blocks_on_blocked_merge_request_id "
t . index [ " blocking_merge_request_id " , " blocked_merge_request_id " ] , name : " index_mr_blocks_on_blocking_and_blocked_mr_ids " , unique : true
2015-04-26 12:48:37 +05:30
end
2017-09-10 17:25:29 +05:30
create_table " merge_request_diff_commits " , id : false , force : :cascade do | t |
2019-12-16 22:33:55 +05:30
t . datetime " authored_date "
t . datetime " committed_date "
2017-09-10 17:25:29 +05:30
t . integer " merge_request_diff_id " , null : false
t . integer " relative_order " , null : false
t . binary " sha " , null : false
t . text " author_name "
t . text " author_email "
t . text " committer_name "
t . text " committer_email "
t . text " message "
2019-12-16 22:33:55 +05:30
t . index [ " merge_request_diff_id " , " relative_order " ] , name : " index_merge_request_diff_commits_on_mr_diff_id_and_order " , unique : true
t . index [ " sha " ] , name : " index_merge_request_diff_commits_on_sha "
2017-09-10 17:25:29 +05:30
end
create_table " merge_request_diff_files " , id : false , force : :cascade do | t |
t . integer " merge_request_diff_id " , null : false
t . integer " relative_order " , null : false
t . boolean " new_file " , null : false
t . boolean " renamed_file " , null : false
t . boolean " deleted_file " , null : false
t . boolean " too_large " , null : false
t . string " a_mode " , null : false
t . string " b_mode " , null : false
t . text " new_path " , null : false
t . text " old_path " , null : false
2019-03-02 22:35:43 +05:30
t . text " diff "
2017-09-10 17:25:29 +05:30
t . boolean " binary "
2019-03-02 22:35:43 +05:30
t . integer " external_diff_offset "
t . integer " external_diff_size "
2019-12-16 22:33:55 +05:30
t . index [ " merge_request_diff_id " , " relative_order " ] , name : " index_merge_request_diff_files_on_mr_diff_id_and_order " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " merge_request_diffs " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " state "
t . integer " merge_request_id " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " base_commit_sha "
t . string " real_size "
t . string " head_commit_sha "
t . string " start_commit_sha "
2018-03-17 18:26:18 +05:30
t . integer " commits_count "
2019-03-02 22:35:43 +05:30
t . string " external_diff "
t . integer " external_diff_store "
t . boolean " stored_externally "
2019-12-16 22:33:55 +05:30
t . index [ " merge_request_id " , " id " ] , name : " index_merge_request_diffs_on_merge_request_id_and_id "
t . index [ " merge_request_id " , " id " ] , name : " index_merge_request_diffs_on_merge_request_id_and_id_partial " , where : " ((NOT stored_externally) OR (stored_externally IS NULL)) "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " merge_request_metrics " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " merge_request_id " , null : false
2016-09-29 09:46:39 +05:30
t . datetime " latest_build_started_at "
t . datetime " latest_build_finished_at "
t . datetime " first_deployed_to_production_at "
t . datetime " merged_at "
2016-11-03 12:29:30 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2017-08-17 22:00:37 +05:30
t . integer " pipeline_id "
2018-03-17 18:26:18 +05:30
t . integer " merged_by_id "
t . integer " latest_closed_by_id "
t . datetime_with_timezone " latest_closed_at "
2019-12-16 22:33:55 +05:30
t . datetime_with_timezone " first_comment_at "
t . datetime_with_timezone " first_commit_at "
t . datetime_with_timezone " last_commit_at "
t . integer " diff_size "
t . integer " modified_paths_size "
t . integer " commits_count "
t . index [ " first_deployed_to_production_at " ] , name : " index_merge_request_metrics_on_first_deployed_to_production_at "
t . index [ " latest_closed_at " ] , name : " index_merge_request_metrics_on_latest_closed_at " , where : " (latest_closed_at IS NOT NULL) "
t . index [ " latest_closed_by_id " ] , name : " index_merge_request_metrics_on_latest_closed_by_id "
t . index [ " merge_request_id " , " merged_at " ] , name : " index_merge_request_metrics_on_merge_request_id_and_merged_at " , where : " (merged_at IS NOT NULL) "
t . index [ " merge_request_id " ] , name : " index_merge_request_metrics "
t . index [ " merged_at " , " id " ] , name : " index_merge_request_metrics_on_merged_at_and_id "
t . index [ " merged_by_id " ] , name : " index_merge_request_metrics_on_merged_by_id "
t . index [ " pipeline_id " ] , name : " index_merge_request_metrics_on_pipeline_id "
2016-09-29 09:46:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " merge_requests " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " target_branch " , null : false
t . string " source_branch " , null : false
2018-03-17 18:26:18 +05:30
t . integer " source_project_id "
2016-11-03 12:29:30 +05:30
t . integer " author_id "
t . integer " assignee_id "
t . string " title "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " milestone_id "
2018-03-17 18:26:18 +05:30
t . string " state " , default : " opened " , null : false
t . string " merge_status " , default : " unchecked " , null : false
2016-11-03 12:29:30 +05:30
t . integer " target_project_id " , null : false
t . integer " iid "
t . text " description "
t . integer " updated_by_id "
t . text " merge_error "
t . text " merge_params "
2017-08-17 22:00:37 +05:30
t . boolean " merge_when_pipeline_succeeds " , default : false , null : false
2016-11-03 12:29:30 +05:30
t . integer " merge_user_id "
t . string " merge_commit_sha "
2019-12-16 22:33:55 +05:30
t . integer " approvals_before_merge "
t . string " rebase_commit_sha "
2016-11-03 12:29:30 +05:30
t . string " in_progress_merge_commit_sha "
t . integer " lock_version "
t . text " title_html "
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . integer " time_estimate "
2019-12-16 22:33:55 +05:30
t . boolean " squash " , default : false , null : false
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
t . datetime " last_edited_at "
t . integer " last_edited_by_id "
2017-09-10 17:25:29 +05:30
t . integer " head_pipeline_id "
t . string " merge_jid "
2018-03-17 18:26:18 +05:30
t . boolean " discussion_locked "
t . integer " latest_merge_request_diff_id "
2018-03-27 19:54:05 +05:30
t . boolean " allow_maintainer_to_push "
2019-12-16 22:33:55 +05:30
t . integer " state_id " , limit : 2
t . string " rebase_jid "
t . index [ " assignee_id " ] , name : " index_merge_requests_on_assignee_id "
t . index [ " author_id " ] , name : " index_merge_requests_on_author_id "
t . index [ " created_at " ] , name : " index_merge_requests_on_created_at "
t . index [ " description " ] , name : " index_merge_requests_on_description_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " head_pipeline_id " ] , name : " index_merge_requests_on_head_pipeline_id "
t . index [ " id " , " merge_jid " ] , name : " index_merge_requests_on_id_and_merge_jid " , where : " ((merge_jid IS NOT NULL) AND ((state)::text = 'locked'::text)) "
t . index [ " latest_merge_request_diff_id " ] , name : " index_merge_requests_on_latest_merge_request_diff_id "
t . index [ " merge_user_id " ] , name : " index_merge_requests_on_merge_user_id " , where : " (merge_user_id IS NOT NULL) "
t . index [ " milestone_id " ] , name : " index_merge_requests_on_milestone_id "
t . index [ " source_branch " ] , name : " index_merge_requests_on_source_branch "
t . index [ " source_project_id " , " source_branch " ] , name : " index_merge_requests_on_source_project_and_branch_state_opened " , where : " ((state)::text = 'opened'::text) "
t . index [ " source_project_id " , " source_branch " ] , name : " index_merge_requests_on_source_project_id_and_source_branch "
t . index [ " state " , " merge_status " ] , name : " index_merge_requests_on_state_and_merge_status " , where : " (((state)::text = 'opened'::text) AND ((merge_status)::text = 'can_be_merged'::text)) "
t . index [ " target_branch " ] , name : " index_merge_requests_on_target_branch "
t . index [ " target_project_id " , " iid " ] , name : " index_merge_requests_on_target_project_id_and_iid " , unique : true
t . index [ " target_project_id " , " iid " ] , name : " index_merge_requests_on_target_project_id_and_iid_opened " , where : " ((state)::text = 'opened'::text) "
t . index [ " target_project_id " , " merge_commit_sha " , " id " ] , name : " index_merge_requests_on_tp_id_and_merge_commit_sha_and_id "
t . index [ " title " ] , name : " index_merge_requests_on_title "
t . index [ " title " ] , name : " index_merge_requests_on_title_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " updated_by_id " ] , name : " index_merge_requests_on_updated_by_id " , where : " (updated_by_id IS NOT NULL) "
end
create_table " merge_requests_closing_issues " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " merge_request_id " , null : false
t . integer " issue_id " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " issue_id " ] , name : " index_merge_requests_closing_issues_on_issue_id "
t . index [ " merge_request_id " ] , name : " index_merge_requests_closing_issues_on_merge_request_id "
end
create_table " merge_trains " , force : :cascade do | t |
t . integer " merge_request_id " , null : false
t . integer " user_id " , null : false
t . integer " pipeline_id "
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " target_project_id " , null : false
t . text " target_branch " , null : false
t . index [ " merge_request_id " ] , name : " index_merge_trains_on_merge_request_id " , unique : true
t . index [ " pipeline_id " ] , name : " index_merge_trains_on_pipeline_id "
t . index [ " target_project_id " ] , name : " index_merge_trains_on_target_project_id "
t . index [ " user_id " ] , name : " index_merge_trains_on_user_id "
end
create_table " milestone_releases " , id : false , force : :cascade do | t |
t . bigint " milestone_id " , null : false
t . bigint " release_id " , null : false
t . index [ " milestone_id " , " release_id " ] , name : " index_miletone_releases_on_milestone_and_release " , unique : true
t . index [ " release_id " ] , name : " index_milestone_releases_on_release_id "
2016-09-29 09:46:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " milestones " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " title " , null : false
2017-09-10 17:25:29 +05:30
t . integer " project_id "
2016-11-03 12:29:30 +05:30
t . text " description "
t . date " due_date "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " state "
t . integer " iid "
t . text " title_html "
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . date " start_date "
t . integer " cached_markdown_version "
2017-09-10 17:25:29 +05:30
t . integer " group_id "
2019-12-16 22:33:55 +05:30
t . index [ " description " ] , name : " index_milestones_on_description_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " due_date " ] , name : " index_milestones_on_due_date "
t . index [ " group_id " ] , name : " index_milestones_on_group_id "
t . index [ " project_id " , " iid " ] , name : " index_milestones_on_project_id_and_iid " , unique : true
t . index [ " title " ] , name : " index_milestones_on_title "
t . index [ " title " ] , name : " index_milestones_on_title_trigram " , opclass : :gin_trgm_ops , using : :gin
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " namespace_aggregation_schedules " , primary_key : " namespace_id " , id : :integer , default : nil , force : :cascade do | t |
t . index [ " namespace_id " ] , name : " index_namespace_aggregation_schedules_on_namespace_id " , unique : true
end
create_table " namespace_root_storage_statistics " , primary_key : " namespace_id " , id : :integer , default : nil , force : :cascade do | t |
t . datetime_with_timezone " updated_at " , null : false
t . bigint " repository_size " , default : 0 , null : false
t . bigint " lfs_objects_size " , default : 0 , null : false
t . bigint " wiki_size " , default : 0 , null : false
t . bigint " build_artifacts_size " , default : 0 , null : false
t . bigint " storage_size " , default : 0 , null : false
t . bigint " packages_size " , default : 0 , null : false
t . index [ " namespace_id " ] , name : " index_namespace_root_storage_statistics_on_namespace_id " , unique : true
end
create_table " namespace_statistics " , id : :serial , force : :cascade do | t |
t . integer " namespace_id " , null : false
t . integer " shared_runners_seconds " , default : 0 , null : false
t . datetime " shared_runners_seconds_last_reset "
t . index [ " namespace_id " ] , name : " index_namespace_statistics_on_namespace_id " , unique : true
end
create_table " namespaces " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " name " , null : false
t . string " path " , null : false
t . integer " owner_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " type "
t . string " description " , default : " " , null : false
t . string " avatar "
2019-12-16 22:33:55 +05:30
t . boolean " membership_lock " , default : false
2016-11-03 12:29:30 +05:30
t . boolean " share_with_group_lock " , default : false
t . integer " visibility_level " , default : 20 , null : false
2017-08-17 22:00:37 +05:30
t . boolean " request_access_enabled " , default : false , null : false
2019-12-16 22:33:55 +05:30
t . string " ldap_sync_status " , default : " ready " , null : false
t . string " ldap_sync_error "
t . datetime " ldap_sync_last_update_at "
t . datetime " ldap_sync_last_successful_update_at "
t . datetime " ldap_sync_last_sync_at "
2016-11-03 12:29:30 +05:30
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . boolean " lfs_enabled "
t . integer " parent_id "
2019-12-16 22:33:55 +05:30
t . integer " shared_runners_minutes_limit "
t . bigint " repository_size_limit "
2017-08-17 22:00:37 +05:30
t . boolean " require_two_factor_authentication " , default : false , null : false
t . integer " two_factor_grace_period " , default : 48 , null : false
t . integer " cached_markdown_version "
2019-12-16 22:33:55 +05:30
t . integer " plan_id "
t . integer " project_creation_level "
2018-10-15 14:42:47 +05:30
t . string " runners_token "
2019-12-16 22:33:55 +05:30
t . datetime_with_timezone " trial_ends_on "
t . integer " file_template_project_id "
t . string " saml_discovery_token "
2019-02-15 15:39:39 +05:30
t . string " runners_token_encrypted "
2019-12-16 22:33:55 +05:30
t . integer " custom_project_templates_group_id "
t . boolean " auto_devops_enabled "
t . integer " extra_shared_runners_minutes_limit "
t . datetime_with_timezone " last_ci_minutes_notification_at "
t . integer " last_ci_minutes_usage_notification_level "
t . integer " subgroup_creation_level " , default : 1
t . boolean " emails_disabled "
t . index [ " created_at " ] , name : " index_namespaces_on_created_at "
t . index [ " custom_project_templates_group_id " , " type " ] , name : " index_namespaces_on_custom_project_templates_group_id_and_type " , where : " (custom_project_templates_group_id IS NOT NULL) "
t . index [ " file_template_project_id " ] , name : " index_namespaces_on_file_template_project_id "
t . index [ " ldap_sync_last_successful_update_at " ] , name : " index_namespaces_on_ldap_sync_last_successful_update_at "
t . index [ " ldap_sync_last_update_at " ] , name : " index_namespaces_on_ldap_sync_last_update_at "
t . index [ " name " , " parent_id " ] , name : " index_namespaces_on_name_and_parent_id " , unique : true
t . index [ " name " ] , name : " index_namespaces_on_name_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " owner_id " ] , name : " index_namespaces_on_owner_id "
t . index [ " parent_id " , " id " ] , name : " index_namespaces_on_parent_id_and_id " , unique : true
t . index [ " path " ] , name : " index_namespaces_on_path "
t . index [ " path " ] , name : " index_namespaces_on_path_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " plan_id " ] , name : " index_namespaces_on_plan_id "
t . index [ " require_two_factor_authentication " ] , name : " index_namespaces_on_require_two_factor_authentication "
t . index [ " runners_token " ] , name : " index_namespaces_on_runners_token " , unique : true
t . index [ " runners_token_encrypted " ] , name : " index_namespaces_on_runners_token_encrypted " , unique : true
t . index [ " shared_runners_minutes_limit " , " extra_shared_runners_minutes_limit " ] , name : " index_namespaces_on_shared_and_extra_runners_minutes_limit "
t . index [ " trial_ends_on " ] , name : " index_namespaces_on_trial_ends_on " , where : " (trial_ends_on IS NOT NULL) "
t . index [ " type " ] , name : " index_namespaces_on_type_partial " , where : " (type IS NOT NULL) "
end
create_table " note_diff_files " , id : :serial , force : :cascade do | t |
2018-11-08 19:23:39 +05:30
t . integer " diff_note_id " , null : false
t . text " diff " , null : false
t . boolean " new_file " , null : false
t . boolean " renamed_file " , null : false
t . boolean " deleted_file " , null : false
t . string " a_mode " , null : false
t . string " b_mode " , null : false
t . text " new_path " , null : false
t . text " old_path " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " diff_note_id " ] , name : " index_note_diff_files_on_diff_note_id " , unique : true
2018-11-08 19:23:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " notes " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . text " note "
t . string " noteable_type "
t . integer " author_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " project_id "
t . string " attachment "
t . string " line_code "
t . string " commit_id "
t . integer " noteable_id "
t . boolean " system " , default : false , null : false
t . text " st_diff "
t . integer " updated_by_id "
t . string " type "
t . text " position "
t . text " original_position "
2016-09-13 17:45:13 +05:30
t . datetime " resolved_at "
2016-11-03 12:29:30 +05:30
t . integer " resolved_by_id "
t . string " discussion_id "
t . text " note_html "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2017-09-10 17:25:29 +05:30
t . text " change_position "
2018-03-17 18:26:18 +05:30
t . boolean " resolved_by_push "
2019-12-16 22:33:55 +05:30
t . bigint " review_id "
t . index [ " author_id " ] , name : " index_notes_on_author_id "
t . index [ " commit_id " ] , name : " index_notes_on_commit_id "
t . index [ " created_at " ] , name : " index_notes_on_created_at "
t . index [ " discussion_id " ] , name : " index_notes_on_discussion_id "
t . index [ " line_code " ] , name : " index_notes_on_line_code "
t . index [ " note " ] , name : " index_notes_on_note_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " noteable_id " , " noteable_type " ] , name : " index_notes_on_noteable_id_and_noteable_type "
t . index [ " project_id " , " id " ] , name : " index_notes_on_project_id_and_id_and_system_false " , where : " (NOT system) "
t . index [ " project_id " , " noteable_type " ] , name : " index_notes_on_project_id_and_noteable_type "
t . index [ " review_id " ] , name : " index_notes_on_review_id "
end
create_table " notification_settings " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id " , null : false
t . integer " source_id "
t . string " source_type "
t . integer " level " , default : 0 , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2017-09-10 17:25:29 +05:30
t . boolean " new_note "
t . boolean " new_issue "
t . boolean " reopen_issue "
t . boolean " close_issue "
t . boolean " reassign_issue "
t . boolean " new_merge_request "
t . boolean " reopen_merge_request "
t . boolean " close_merge_request "
t . boolean " reassign_merge_request "
t . boolean " merge_merge_request "
t . boolean " failed_pipeline "
t . boolean " success_pipeline "
2018-05-09 12:01:36 +05:30
t . boolean " push_to_merge_request "
2018-10-15 14:42:47 +05:30
t . boolean " issue_due "
2019-12-16 22:33:55 +05:30
t . boolean " new_epic "
t . string " notification_email "
t . index [ " source_id " , " source_type " ] , name : " index_notification_settings_on_source_id_and_source_type "
t . index [ " user_id " , " source_id " , " source_type " ] , name : " index_notifications_on_user_id_and_source_id_and_source_type " , unique : true
t . index [ " user_id " ] , name : " index_notification_settings_on_user_id "
2016-06-02 11:05:42 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " oauth_access_grants " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " resource_owner_id " , null : false
t . integer " application_id " , null : false
t . string " token " , null : false
t . integer " expires_in " , null : false
t . text " redirect_uri " , null : false
t . datetime " created_at " , null : false
2015-04-26 12:48:37 +05:30
t . datetime " revoked_at "
2016-11-03 12:29:30 +05:30
t . string " scopes "
2019-12-16 22:33:55 +05:30
t . index [ " token " ] , name : " index_oauth_access_grants_on_token " , unique : true
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " oauth_access_tokens " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " resource_owner_id "
t . integer " application_id "
t . string " token " , null : false
t . string " refresh_token "
t . integer " expires_in "
2015-04-26 12:48:37 +05:30
t . datetime " revoked_at "
2016-11-03 12:29:30 +05:30
t . datetime " created_at " , null : false
t . string " scopes "
2019-12-16 22:33:55 +05:30
t . index [ " application_id " ] , name : " index_oauth_access_tokens_on_application_id "
t . index [ " refresh_token " ] , name : " index_oauth_access_tokens_on_refresh_token " , unique : true
t . index [ " resource_owner_id " ] , name : " index_oauth_access_tokens_on_resource_owner_id "
t . index [ " token " ] , name : " index_oauth_access_tokens_on_token " , unique : true
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " oauth_applications " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " name " , null : false
t . string " uid " , null : false
t . string " secret " , null : false
t . text " redirect_uri " , null : false
t . string " scopes " , default : " " , null : false
2015-04-26 12:48:37 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " owner_id "
t . string " owner_type "
2017-09-10 17:25:29 +05:30
t . boolean " trusted " , default : false , null : false
2019-12-16 22:33:55 +05:30
t . index [ " owner_id " , " owner_type " ] , name : " index_oauth_applications_on_owner_id_and_owner_type "
t . index [ " uid " ] , name : " index_oauth_applications_on_uid " , unique : true
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " oauth_openid_requests " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " access_grant_id " , null : false
t . string " nonce " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " access_grant_id " ] , name : " index_oauth_openid_requests_on_access_grant_id "
end
create_table " operations_feature_flag_scopes " , force : :cascade do | t |
t . bigint " feature_flag_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . boolean " active " , null : false
t . string " environment_scope " , default : " * " , null : false
t . jsonb " strategies " , default : [ { " name " = > " default " , " parameters " = > { } } ] , null : false
t . index [ " feature_flag_id " , " environment_scope " ] , name : " index_feature_flag_scopes_on_flag_id_and_environment_scope " , unique : true
end
create_table " operations_feature_flags " , force : :cascade do | t |
t . integer " project_id " , null : false
t . boolean " active " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " name " , null : false
t . text " description "
t . index [ " project_id " , " name " ] , name : " index_operations_feature_flags_on_project_id_and_name " , unique : true
end
create_table " operations_feature_flags_clients " , force : :cascade do | t |
t . integer " project_id " , null : false
t . string " token "
t . string " token_encrypted "
t . index [ " project_id " , " token " ] , name : " index_operations_feature_flags_clients_on_project_id_and_token " , unique : true
t . index [ " project_id " , " token_encrypted " ] , name : " index_feature_flags_clients_on_project_id_and_token_encrypted " , unique : true
end
create_table " packages_maven_metadata " , force : :cascade do | t |
t . bigint " package_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " app_group " , null : false
t . string " app_name " , null : false
t . string " app_version "
t . string " path " , limit : 512 , null : false
t . index [ " package_id " , " path " ] , name : " index_packages_maven_metadata_on_package_id_and_path "
end
create_table " packages_package_files " , force : :cascade do | t |
t . bigint " package_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . bigint " size "
t . integer " file_type "
t . integer " file_store "
t . binary " file_md5 "
t . binary " file_sha1 "
t . string " file_name " , null : false
t . text " file " , null : false
t . index [ " package_id " , " file_name " ] , name : " index_packages_package_files_on_package_id_and_file_name "
end
create_table " packages_package_metadata " , force : :cascade do | t |
t . integer " package_id " , null : false
t . binary " metadata " , null : false
t . index [ " package_id " ] , name : " index_packages_package_metadata_on_package_id " , unique : true
end
create_table " packages_package_tags " , force : :cascade do | t |
t . integer " package_id " , null : false
t . string " name " , limit : 255 , null : false
t . index [ " package_id " ] , name : " index_packages_package_tags_on_package_id "
end
create_table " packages_packages " , force : :cascade do | t |
t . integer " project_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " name " , null : false
t . string " version "
t . integer " package_type " , limit : 2 , null : false
t . index [ " project_id " ] , name : " index_packages_packages_on_project_id "
end
create_table " pages_domain_acme_orders " , force : :cascade do | t |
t . integer " pages_domain_id " , null : false
t . datetime_with_timezone " expires_at " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " url " , null : false
t . string " challenge_token " , null : false
t . text " challenge_file_content " , null : false
t . text " encrypted_private_key " , null : false
t . text " encrypted_private_key_iv " , null : false
t . index [ " challenge_token " ] , name : " index_pages_domain_acme_orders_on_challenge_token "
t . index [ " pages_domain_id " ] , name : " index_pages_domain_acme_orders_on_pages_domain_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " pages_domains " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " project_id "
t . text " certificate "
t . text " encrypted_key "
t . string " encrypted_key_iv "
t . string " encrypted_key_salt "
t . string " domain "
2018-03-17 18:26:18 +05:30
t . datetime_with_timezone " verified_at "
t . string " verification_code " , null : false
t . datetime_with_timezone " enabled_until "
2019-12-16 22:33:55 +05:30
t . datetime_with_timezone " remove_at "
t . boolean " auto_ssl_enabled " , default : false , null : false
t . datetime_with_timezone " certificate_valid_not_before "
t . datetime_with_timezone " certificate_valid_not_after "
t . integer " certificate_source " , limit : 2 , default : 0 , null : false
t . index [ " certificate_source " , " certificate_valid_not_after " ] , name : " index_pages_domains_need_auto_ssl_renewal " , where : " (auto_ssl_enabled = true) "
t . index [ " domain " ] , name : " index_pages_domains_on_domain " , unique : true
t . index [ " project_id " , " enabled_until " ] , name : " index_pages_domains_on_project_id_and_enabled_until "
t . index [ " project_id " ] , name : " index_pages_domains_on_project_id "
t . index [ " remove_at " ] , name : " index_pages_domains_on_remove_at "
t . index [ " verified_at " , " enabled_until " ] , name : " index_pages_domains_on_verified_at_and_enabled_until "
t . index [ " verified_at " ] , name : " index_pages_domains_on_verified_at "
end
create_table " path_locks " , id : :serial , force : :cascade do | t |
t . string " path " , null : false
t . integer " project_id "
t . integer " user_id "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . index [ " path " ] , name : " index_path_locks_on_path "
t . index [ " project_id " ] , name : " index_path_locks_on_project_id "
t . index [ " user_id " ] , name : " index_path_locks_on_user_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " personal_access_tokens " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id " , null : false
t . string " name " , null : false
t . boolean " revoked " , default : false
2017-08-17 22:00:37 +05:30
t . date " expires_at "
2016-11-03 12:29:30 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2017-08-17 22:00:37 +05:30
t . string " scopes " , default : " --- [] \n " , null : false
t . boolean " impersonation " , default : false , null : false
2018-11-18 11:00:15 +05:30
t . string " token_digest "
2019-12-16 22:33:55 +05:30
t . index [ " token_digest " ] , name : " index_personal_access_tokens_on_token_digest " , unique : true
t . index [ " user_id " ] , name : " index_personal_access_tokens_on_user_id "
end
create_table " plans " , id : :serial , force : :cascade do | t |
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . string " name "
t . string " title "
t . integer " active_pipelines_limit "
t . integer " pipeline_size_limit "
t . integer " active_jobs_limit " , default : 0
t . index [ " name " ] , name : " index_plans_on_name "
2016-06-22 15:30:34 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " pool_repositories " , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . integer " shard_id " , null : false
t . string " disk_path "
t . string " state "
t . integer " source_project_id "
2019-12-16 22:33:55 +05:30
t . index [ " disk_path " ] , name : " index_pool_repositories_on_disk_path " , unique : true
t . index [ " shard_id " ] , name : " index_pool_repositories_on_shard_id "
t . index [ " source_project_id " ] , name : " index_pool_repositories_on_source_project_id " , unique : true
2019-02-15 15:39:39 +05:30
end
2016-06-22 15:30:34 +05:30
2019-12-16 22:33:55 +05:30
create_table " programming_languages " , id : :serial , force : :cascade do | t |
2018-11-18 11:00:15 +05:30
t . string " name " , null : false
t . string " color " , null : false
t . datetime_with_timezone " created_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " name " ] , name : " index_programming_languages_on_name " , unique : true
end
create_table " project_alerting_settings " , primary_key : " project_id " , id : :integer , default : nil , force : :cascade do | t |
t . string " encrypted_token " , null : false
t . string " encrypted_token_iv " , null : false
end
create_table " project_aliases " , force : :cascade do | t |
t . integer " project_id " , null : false
t . string " name " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . index [ " name " ] , name : " index_project_aliases_on_name " , unique : true
t . index [ " project_id " ] , name : " index_project_aliases_on_project_id "
2018-11-18 11:00:15 +05:30
end
2017-08-17 22:00:37 +05:30
create_table " project_authorizations " , id : false , force : :cascade do | t |
2018-11-08 19:23:39 +05:30
t . integer " user_id " , null : false
t . integer " project_id " , null : false
t . integer " access_level " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_project_authorizations_on_project_id "
t . index [ " user_id " , " project_id " , " access_level " ] , name : " index_project_authorizations_on_user_id_project_id_access_level " , unique : true
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_auto_devops " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . boolean " enabled "
2018-11-08 19:23:39 +05:30
t . integer " deploy_strategy " , default : 0 , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_project_auto_devops_on_project_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_ci_cd_settings " , id : :serial , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " project_id " , null : false
t . boolean " group_runners_enabled " , default : true , null : false
2019-12-16 22:33:55 +05:30
t . boolean " merge_pipelines_enabled "
t . boolean " merge_trains_enabled " , default : false , null : false
t . integer " default_git_depth "
t . index [ " project_id " ] , name : " index_project_ci_cd_settings_on_project_id " , unique : true
2018-10-15 14:42:47 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_custom_attributes " , id : :serial , force : :cascade do | t |
2018-12-05 23:21:45 +05:30
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . integer " project_id " , null : false
t . string " key " , null : false
t . string " value " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " key " , " value " ] , name : " index_project_custom_attributes_on_key_and_value "
t . index [ " project_id " , " key " ] , name : " index_project_custom_attributes_on_project_id_and_key " , unique : true
end
create_table " project_daily_statistics " , force : :cascade do | t |
t . integer " project_id " , null : false
t . integer " fetch_count " , null : false
t . date " date "
t . index [ " project_id " , " date " ] , name : " index_project_daily_statistics_on_project_id_and_date " , unique : true , order : { date : :desc }
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_deploy_tokens " , id : :serial , force : :cascade do | t |
2018-05-09 12:01:36 +05:30
t . integer " project_id " , null : false
t . integer " deploy_token_id " , null : false
t . datetime_with_timezone " created_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " deploy_token_id " ] , name : " index_project_deploy_tokens_on_deploy_token_id "
t . index [ " project_id " , " deploy_token_id " ] , name : " index_project_deploy_tokens_on_project_id_and_deploy_token_id " , unique : true
2018-05-09 12:01:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_error_tracking_settings " , primary_key : " project_id " , id : :integer , default : nil , force : :cascade do | t |
2019-03-02 22:35:43 +05:30
t . boolean " enabled " , default : false , null : false
t . string " api_url "
2019-02-15 15:39:39 +05:30
t . string " encrypted_token "
t . string " encrypted_token_iv "
2019-03-02 22:35:43 +05:30
t . string " project_name "
t . string " organization_name "
2019-02-15 15:39:39 +05:30
end
2019-01-03 12:48:30 +05:30
2019-12-16 22:33:55 +05:30
create_table " project_feature_usages " , primary_key : " project_id " , id : :integer , default : nil , force : :cascade do | t |
t . datetime " jira_dvcs_cloud_last_sync_at "
t . datetime " jira_dvcs_server_last_sync_at "
t . index [ " jira_dvcs_cloud_last_sync_at " , " project_id " ] , name : " idx_proj_feat_usg_on_jira_dvcs_cloud_last_sync_at_and_proj_id " , where : " (jira_dvcs_cloud_last_sync_at IS NOT NULL) "
t . index [ " jira_dvcs_server_last_sync_at " , " project_id " ] , name : " idx_proj_feat_usg_on_jira_dvcs_server_last_sync_at_and_proj_id " , where : " (jira_dvcs_server_last_sync_at IS NOT NULL) "
t . index [ " project_id " ] , name : " index_project_feature_usages_on_project_id "
end
create_table " project_features " , id : :serial , force : :cascade do | t |
2018-11-08 19:23:39 +05:30
t . integer " project_id " , null : false
2016-11-03 12:29:30 +05:30
t . integer " merge_requests_access_level "
t . integer " issues_access_level "
t . integer " wiki_access_level "
2018-12-13 13:39:08 +05:30
t . integer " snippets_access_level " , default : 20 , null : false
2016-11-03 12:29:30 +05:30
t . integer " builds_access_level "
2016-09-29 09:46:39 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " repository_access_level " , default : 20 , null : false
2019-12-16 22:33:55 +05:30
t . integer " pages_access_level " , null : false
t . index [ " project_id " ] , name : " index_project_features_on_project_id " , unique : true
2016-09-29 09:46:39 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_group_links " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " project_id " , null : false
t . integer " group_id " , null : false
2016-06-02 11:05:42 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " group_access " , default : 30 , null : false
t . date " expires_at "
2019-12-16 22:33:55 +05:30
t . index [ " group_id " ] , name : " index_project_group_links_on_group_id "
t . index [ " project_id " ] , name : " index_project_group_links_on_project_id "
2016-06-02 11:05:42 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_import_data " , id : :serial , force : :cascade do | t |
2015-04-26 12:48:37 +05:30
t . integer " project_id "
2016-11-03 12:29:30 +05:30
t . text " data "
t . text " encrypted_credentials "
t . string " encrypted_credentials_iv "
t . string " encrypted_credentials_salt "
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_project_import_data_on_project_id "
end
create_table " project_incident_management_settings " , primary_key : " project_id " , id : :serial , force : :cascade do | t |
t . boolean " create_issue " , default : true , null : false
t . boolean " send_email " , default : false , null : false
t . text " issue_template_key "
end
create_table " project_metrics_settings " , primary_key : " project_id " , id : :integer , default : nil , force : :cascade do | t |
t . string " external_dashboard_url " , null : false
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_mirror_data " , id : :serial , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " project_id " , null : false
2019-12-16 22:33:55 +05:30
t . integer " retry_count " , default : 0 , null : false
t . datetime " last_update_started_at "
t . datetime " last_update_scheduled_at "
t . datetime " next_execution_timestamp "
2018-10-15 14:42:47 +05:30
t . string " status "
t . string " jid "
t . text " last_error "
2019-12-16 22:33:55 +05:30
t . datetime_with_timezone " last_update_at "
t . datetime_with_timezone " last_successful_update_at "
t . index [ " jid " ] , name : " index_project_mirror_data_on_jid "
t . index [ " last_successful_update_at " ] , name : " index_project_mirror_data_on_last_successful_update_at "
t . index [ " last_update_at " , " retry_count " ] , name : " index_project_mirror_data_on_last_update_at_and_retry_count "
t . index [ " next_execution_timestamp " , " retry_count " ] , name : " index_mirror_data_on_next_execution_and_retry_count "
t . index [ " project_id " ] , name : " index_project_mirror_data_on_project_id " , unique : true
t . index [ " status " ] , name : " index_project_mirror_data_on_status "
2018-10-15 14:42:47 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " project_repositories " , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . integer " shard_id " , null : false
t . string " disk_path " , null : false
t . integer " project_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " disk_path " ] , name : " index_project_repositories_on_disk_path " , unique : true
t . index [ " project_id " ] , name : " index_project_repositories_on_project_id " , unique : true
t . index [ " shard_id " ] , name : " index_project_repositories_on_shard_id "
2019-02-15 15:39:39 +05:30
end
2018-10-15 14:42:47 +05:30
2019-12-16 22:33:55 +05:30
create_table " project_repository_states " , id : :serial , force : :cascade do | t |
t . integer " project_id " , null : false
t . binary " repository_verification_checksum "
t . binary " wiki_verification_checksum "
t . string " last_repository_verification_failure "
t . string " last_wiki_verification_failure "
t . datetime_with_timezone " repository_retry_at "
t . datetime_with_timezone " wiki_retry_at "
t . integer " repository_retry_count "
t . integer " wiki_retry_count "
t . datetime_with_timezone " last_repository_verification_ran_at "
t . datetime_with_timezone " last_wiki_verification_ran_at "
t . index [ " last_repository_verification_failure " ] , name : " idx_repository_states_on_repository_failure_partial " , where : " (last_repository_verification_failure IS NOT NULL) "
t . index [ " last_wiki_verification_failure " ] , name : " idx_repository_states_on_wiki_failure_partial " , where : " (last_wiki_verification_failure IS NOT NULL) "
t . index [ " project_id " , " last_repository_verification_ran_at " ] , name : " idx_repository_states_on_last_repository_verification_ran_at " , where : " ((repository_verification_checksum IS NOT NULL) AND (last_repository_verification_failure IS NULL)) "
t . index [ " project_id " , " last_wiki_verification_ran_at " ] , name : " idx_repository_states_on_last_wiki_verification_ran_at " , where : " ((wiki_verification_checksum IS NOT NULL) AND (last_wiki_verification_failure IS NULL)) "
t . index [ " project_id " ] , name : " idx_repository_states_outdated_checksums " , where : " (((repository_verification_checksum IS NULL) AND (last_repository_verification_failure IS NULL)) OR ((wiki_verification_checksum IS NULL) AND (last_wiki_verification_failure IS NULL))) "
t . index [ " project_id " ] , name : " index_project_repository_states_on_project_id " , unique : true
end
create_table " project_statistics " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " project_id " , null : false
t . integer " namespace_id " , null : false
2019-02-15 15:39:39 +05:30
t . bigint " commit_count " , default : 0 , null : false
t . bigint " storage_size " , default : 0 , null : false
t . bigint " repository_size " , default : 0 , null : false
t . bigint " lfs_objects_size " , default : 0 , null : false
t . bigint " build_artifacts_size " , default : 0 , null : false
2019-12-16 22:33:55 +05:30
t . bigint " shared_runners_seconds " , default : 0 , null : false
t . datetime " shared_runners_seconds_last_reset "
t . bigint " packages_size " , default : 0 , null : false
t . bigint " wiki_size "
t . index [ " namespace_id " ] , name : " index_project_statistics_on_namespace_id "
t . index [ " project_id " ] , name : " index_project_statistics_on_project_id " , unique : true
end
create_table " project_tracing_settings " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " project_id " , null : false
t . string " external_url " , null : false
t . index [ " project_id " ] , name : " index_project_tracing_settings_on_project_id " , unique : true
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " projects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " name "
t . string " path "
t . text " description "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " creator_id "
2018-03-27 19:54:05 +05:30
t . integer " namespace_id " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " last_activity_at "
2016-11-03 12:29:30 +05:30
t . string " import_url "
t . integer " visibility_level " , default : 0 , null : false
t . boolean " archived " , default : false , null : false
t . string " avatar "
2019-12-16 22:33:55 +05:30
t . text " merge_requests_template "
2016-11-03 12:29:30 +05:30
t . integer " star_count " , default : 0 , null : false
2019-12-16 22:33:55 +05:30
t . boolean " merge_requests_rebase_enabled " , default : false
2016-11-03 12:29:30 +05:30
t . string " import_type "
t . string " import_source "
2019-12-16 22:33:55 +05:30
t . integer " approvals_before_merge " , default : 0 , null : false
t . boolean " reset_approvals_on_push " , default : true
t . boolean " merge_requests_ff_only_enabled " , default : false
t . text " issues_template "
t . boolean " mirror " , default : false , null : false
t . datetime " mirror_last_update_at "
t . datetime " mirror_last_successful_update_at "
t . integer " mirror_user_id "
2016-11-03 12:29:30 +05:30
t . boolean " shared_runners_enabled " , default : true , null : false
t . string " runners_token "
t . string " build_coverage_regex "
t . boolean " build_allow_git_fetch " , default : true , null : false
t . integer " build_timeout " , default : 3600 , null : false
2019-12-16 22:33:55 +05:30
t . boolean " mirror_trigger_builds " , default : false , null : false
2016-11-03 12:29:30 +05:30
t . boolean " pending_delete " , default : false
t . boolean " public_builds " , default : true , null : false
t . boolean " last_repository_check_failed "
2016-06-02 11:05:42 +05:30
t . datetime " last_repository_check_at "
2016-11-03 12:29:30 +05:30
t . boolean " container_registry_enabled "
2017-08-17 22:00:37 +05:30
t . boolean " only_allow_merge_if_pipeline_succeeds " , default : false , null : false
2016-11-03 12:29:30 +05:30
t . boolean " has_external_issue_tracker "
t . string " repository_storage " , default : " default " , null : false
2019-12-16 22:33:55 +05:30
t . boolean " repository_read_only "
2017-08-17 22:00:37 +05:30
t . boolean " request_access_enabled " , default : false , null : false
2016-11-03 12:29:30 +05:30
t . boolean " has_external_wiki "
2018-03-17 18:26:18 +05:30
t . string " ci_config_path "
2016-11-03 12:29:30 +05:30
t . boolean " lfs_enabled "
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . boolean " only_allow_merge_if_all_discussions_are_resolved "
2019-12-16 22:33:55 +05:30
t . bigint " repository_size_limit "
2017-08-17 22:00:37 +05:30
t . boolean " printing_merge_request_link_enabled " , default : true , null : false
2017-09-10 17:25:29 +05:30
t . integer " auto_cancel_pending_pipelines " , default : 1 , null : false
2019-12-16 22:33:55 +05:30
t . boolean " service_desk_enabled " , default : true
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2017-09-10 17:25:29 +05:30
t . text " delete_error "
2018-03-17 18:26:18 +05:30
t . datetime " last_repository_updated_at "
2019-12-16 22:33:55 +05:30
t . boolean " disable_overriding_approvers_per_merge_request "
2018-03-17 18:26:18 +05:30
t . integer " storage_version " , limit : 2
t . boolean " resolve_outdated_diff_discussions "
2019-12-16 22:33:55 +05:30
t . boolean " remote_mirror_available_overridden "
t . boolean " only_mirror_protected_branches "
t . boolean " pull_mirror_available_overridden "
2018-03-17 18:26:18 +05:30
t . integer " jobs_cache_index "
2019-12-16 22:33:55 +05:30
t . string " external_authorization_classification_label "
t . boolean " mirror_overwrites_diverged_branches "
2018-05-09 12:01:36 +05:30
t . boolean " pages_https_only " , default : true
2019-12-16 22:33:55 +05:30
t . string " external_webhook_token "
t . boolean " packages_enabled "
t . boolean " merge_requests_author_approval "
2019-02-15 15:39:39 +05:30
t . bigint " pool_repository_id "
t . string " runners_token_encrypted "
t . string " bfg_object_map "
2019-12-16 22:33:55 +05:30
t . boolean " merge_requests_require_code_owner_approval "
t . boolean " detected_repository_languages "
t . boolean " merge_requests_disable_committers_approval "
t . boolean " require_password_to_approve "
t . boolean " emails_disabled "
t . index [ " archived " , " pending_delete " , " merge_requests_require_code_owner_approval " ] , name : " projects_requiring_code_owner_approval " , where : " ((pending_delete = false) AND (archived = false) AND (merge_requests_require_code_owner_approval = true)) "
t . index [ " created_at " ] , name : " index_projects_on_created_at "
t . index [ " creator_id " ] , name : " index_projects_on_creator_id "
t . index [ " description " ] , name : " index_projects_on_description_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " id " , " repository_storage " , " last_repository_updated_at " ] , name : " idx_projects_on_repository_storage_last_repository_updated_at "
t . index [ " id " ] , name : " index_projects_on_id_partial_for_visibility " , unique : true , where : " (visibility_level = ANY (ARRAY[10, 20])) "
t . index [ " id " ] , name : " index_projects_on_mirror_and_mirror_trigger_builds_both_true " , where : " ((mirror IS TRUE) AND (mirror_trigger_builds IS TRUE)) "
t . index [ " last_activity_at " ] , name : " index_projects_on_last_activity_at "
t . index [ " last_repository_check_at " ] , name : " index_projects_on_last_repository_check_at " , where : " (last_repository_check_at IS NOT NULL) "
t . index [ " last_repository_check_failed " ] , name : " index_projects_on_last_repository_check_failed "
t . index [ " last_repository_updated_at " ] , name : " index_projects_on_last_repository_updated_at "
t . index [ " mirror_last_successful_update_at " ] , name : " index_projects_on_mirror_last_successful_update_at "
t . index [ " mirror_user_id " ] , name : " index_projects_on_mirror_user_id "
t . index [ " name " ] , name : " index_projects_on_name_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " namespace_id " ] , name : " index_projects_on_namespace_id "
t . index [ " path " ] , name : " index_projects_on_path "
t . index [ " path " ] , name : " index_projects_on_path_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " pending_delete " ] , name : " index_projects_on_pending_delete "
t . index [ " pool_repository_id " ] , name : " index_projects_on_pool_repository_id " , where : " (pool_repository_id IS NOT NULL) "
t . index [ " repository_storage " , " created_at " ] , name : " idx_project_repository_check_partial " , where : " (last_repository_check_at IS NULL) "
t . index [ " repository_storage " ] , name : " index_projects_on_repository_storage "
t . index [ " runners_token " ] , name : " index_projects_on_runners_token "
t . index [ " runners_token_encrypted " ] , name : " index_projects_on_runners_token_encrypted "
t . index [ " star_count " ] , name : " index_projects_on_star_count "
t . index [ " visibility_level " ] , name : " index_projects_on_visibility_level "
end
create_table " prometheus_alert_events " , force : :cascade do | t |
t . integer " project_id " , null : false
t . integer " prometheus_alert_id " , null : false
t . datetime_with_timezone " started_at " , null : false
t . datetime_with_timezone " ended_at "
t . integer " status " , limit : 2
t . string " payload_key "
t . index [ " project_id " , " status " ] , name : " index_prometheus_alert_events_on_project_id_and_status "
t . index [ " prometheus_alert_id " , " payload_key " ] , name : " index_prometheus_alert_event_scoped_payload_key " , unique : true
end
create_table " prometheus_alerts " , id : :serial , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . float " threshold " , null : false
t . integer " operator " , null : false
t . integer " environment_id " , null : false
t . integer " project_id " , null : false
t . integer " prometheus_metric_id " , null : false
t . index [ " environment_id " ] , name : " index_prometheus_alerts_on_environment_id "
t . index [ " project_id " , " prometheus_metric_id " , " environment_id " ] , name : " index_prometheus_alerts_metric_environment " , unique : true
t . index [ " prometheus_metric_id " ] , name : " index_prometheus_alerts_on_prometheus_metric_id "
end
create_table " prometheus_metrics " , id : :serial , force : :cascade do | t |
2018-11-20 20:47:30 +05:30
t . integer " project_id "
t . string " title " , null : false
t . string " query " , null : false
2019-12-16 22:33:55 +05:30
t . string " y_label " , null : false
t . string " unit " , null : false
2018-11-20 20:47:30 +05:30
t . string " legend "
t . integer " group " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . boolean " common " , default : false , null : false
t . string " identifier "
2019-12-16 22:33:55 +05:30
t . index [ " common " ] , name : " index_prometheus_metrics_on_common "
t . index [ " group " ] , name : " index_prometheus_metrics_on_group "
t . index [ " identifier " ] , name : " index_prometheus_metrics_on_identifier " , unique : true
t . index [ " project_id " ] , name : " index_prometheus_metrics_on_project_id "
2018-11-20 20:47:30 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " protected_branch_merge_access_levels " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " protected_branch_id " , null : false
2019-12-16 22:33:55 +05:30
t . integer " access_level " , default : 40
2016-11-03 12:29:30 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . integer " user_id "
t . integer " group_id "
t . index [ " group_id " ] , name : " index_protected_branch_merge_access_levels_on_group_id "
t . index [ " protected_branch_id " ] , name : " index_protected_branch_merge_access "
t . index [ " user_id " ] , name : " index_protected_branch_merge_access_levels_on_user_id "
2016-09-13 17:45:13 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " protected_branch_push_access_levels " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " protected_branch_id " , null : false
2019-12-16 22:33:55 +05:30
t . integer " access_level " , default : 40
2016-11-03 12:29:30 +05:30
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . integer " user_id "
t . integer " group_id "
t . index [ " group_id " ] , name : " index_protected_branch_push_access_levels_on_group_id "
t . index [ " protected_branch_id " ] , name : " index_protected_branch_push_access "
t . index [ " user_id " ] , name : " index_protected_branch_push_access_levels_on_user_id "
end
create_table " protected_branch_unprotect_access_levels " , id : :serial , force : :cascade do | t |
t . integer " protected_branch_id " , null : false
t . integer " access_level " , default : 40
t . integer " user_id "
t . integer " group_id "
t . index [ " group_id " ] , name : " index_protected_branch_unprotect_access_levels_on_group_id "
t . index [ " protected_branch_id " ] , name : " index_protected_branch_unprotect_access "
t . index [ " user_id " ] , name : " index_protected_branch_unprotect_access_levels_on_user_id "
2016-09-13 17:45:13 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " protected_branches " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " project_id " , null : false
t . string " name " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . boolean " code_owner_approval_required " , default : false , null : false
t . index [ " project_id " , " code_owner_approval_required " ] , name : " code_owner_approval_required " , where : " (code_owner_approval_required = true) "
t . index [ " project_id " ] , name : " index_protected_branches_on_project_id "
end
create_table " protected_environment_deploy_access_levels " , id : :serial , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " access_level " , default : 40
t . integer " protected_environment_id " , null : false
t . integer " user_id "
t . integer " group_id "
t . index [ " group_id " ] , name : " index_protected_environment_deploy_access_levels_on_group_id "
t . index [ " protected_environment_id " ] , name : " index_protected_environment_deploy_access "
t . index [ " user_id " ] , name : " index_protected_environment_deploy_access_levels_on_user_id "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " protected_environments " , id : :serial , force : :cascade do | t |
t . integer " project_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . string " name " , null : false
t . index [ " project_id " , " name " ] , name : " index_protected_environments_on_project_id_and_name " , unique : true
t . index [ " project_id " ] , name : " index_protected_environments_on_project_id "
end
create_table " protected_tag_create_access_levels " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " protected_tag_id " , null : false
t . integer " access_level " , default : 40
t . integer " user_id "
t . integer " group_id "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " group_id " ] , name : " index_protected_tag_create_access_levels_on_group_id "
t . index [ " protected_tag_id " ] , name : " index_protected_tag_create_access "
t . index [ " user_id " ] , name : " index_protected_tag_create_access_levels_on_user_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " protected_tags " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " project_id " , null : false
t . string " name " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " , " name " ] , name : " index_protected_tags_on_project_id_and_name " , unique : true
t . index [ " project_id " ] , name : " index_protected_tags_on_project_id "
2017-08-17 22:00:37 +05:30
end
2017-09-10 17:25:29 +05:30
create_table " push_event_payloads " , id : false , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . bigint " commit_count " , null : false
2017-09-10 17:25:29 +05:30
t . integer " event_id " , null : false
t . integer " action " , limit : 2 , null : false
t . integer " ref_type " , limit : 2 , null : false
t . binary " commit_from "
t . binary " commit_to "
t . text " ref "
t . string " commit_title " , limit : 70
2019-12-16 22:33:55 +05:30
t . index [ " event_id " ] , name : " index_push_event_payloads_on_event_id " , unique : true
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " push_rules " , id : :serial , force : :cascade do | t |
t . string " force_push_regex "
t . string " delete_branch_regex "
t . string " commit_message_regex "
t . boolean " deny_delete_tag "
t . integer " project_id "
t . datetime " created_at "
t . datetime " updated_at "
t . string " author_email_regex "
t . boolean " member_check " , default : false , null : false
t . string " file_name_regex "
t . boolean " is_sample " , default : false
t . integer " max_file_size " , default : 0 , null : false
t . boolean " prevent_secrets " , default : false , null : false
t . string " branch_name_regex "
t . boolean " reject_unsigned_commits "
t . boolean " commit_committer_check "
t . boolean " regexp_uses_re2 " , default : true
t . string " commit_message_negative_regex "
t . index [ " is_sample " ] , name : " index_push_rules_on_is_sample " , where : " is_sample "
t . index [ " project_id " ] , name : " index_push_rules_on_project_id "
end
create_table " redirect_routes " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " source_id " , null : false
t . string " source_type " , null : false
t . string " path " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " path " ] , name : " index_redirect_routes_on_path " , unique : true
t . index [ " source_type " , " source_id " ] , name : " index_redirect_routes_on_source_type_and_source_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " release_links " , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . integer " release_id " , null : false
t . string " url " , null : false
t . string " name " , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " release_id " , " name " ] , name : " index_release_links_on_release_id_and_name " , unique : true
t . index [ " release_id " , " url " ] , name : " index_release_links_on_release_id_and_url " , unique : true
2019-02-15 15:39:39 +05:30
end
2019-01-03 12:48:30 +05:30
2019-12-16 22:33:55 +05:30
create_table " releases " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " tag "
t . text " description "
t . integer " project_id "
2015-11-26 14:37:03 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . text " description_html "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2019-02-15 15:39:39 +05:30
t . integer " author_id "
t . string " name "
t . string " sha "
2019-12-16 22:33:55 +05:30
t . datetime_with_timezone " released_at " , null : false
t . index [ " author_id " ] , name : " index_releases_on_author_id "
t . index [ " project_id " , " tag " ] , name : " index_releases_on_project_id_and_tag "
2015-11-26 14:37:03 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " remote_mirrors " , id : :serial , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " project_id "
t . string " url "
t . boolean " enabled " , default : false
t . string " update_status "
t . datetime " last_update_at "
t . datetime " last_successful_update_at "
t . string " last_error "
t . text " encrypted_credentials "
t . string " encrypted_credentials_iv "
t . string " encrypted_credentials_salt "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " last_update_started_at "
t . boolean " only_protected_branches " , default : false , null : false
t . string " remote_name "
2019-02-15 15:39:39 +05:30
t . boolean " error_notification_sent "
2019-12-16 22:33:55 +05:30
t . index [ " last_successful_update_at " ] , name : " index_remote_mirrors_on_last_successful_update_at "
t . index [ " project_id " ] , name : " index_remote_mirrors_on_project_id "
2018-10-15 14:42:47 +05:30
end
2018-11-18 11:00:15 +05:30
create_table " repository_languages " , id : false , force : :cascade do | t |
t . integer " project_id " , null : false
t . integer " programming_language_id " , null : false
t . float " share " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " , " programming_language_id " ] , name : " index_repository_languages_on_project_and_languages_id " , unique : true
2018-11-18 11:00:15 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " resource_label_events " , force : :cascade do | t |
2018-11-18 11:00:15 +05:30
t . integer " action " , null : false
t . integer " issue_id "
t . integer " merge_request_id "
2019-12-16 22:33:55 +05:30
t . integer " epic_id "
2018-11-18 11:00:15 +05:30
t . integer " label_id "
t . integer " user_id "
t . datetime_with_timezone " created_at " , null : false
2018-11-20 20:47:30 +05:30
t . integer " cached_markdown_version "
t . text " reference "
t . text " reference_html "
2019-12-16 22:33:55 +05:30
t . index [ " epic_id " ] , name : " index_resource_label_events_on_epic_id "
t . index [ " issue_id " ] , name : " index_resource_label_events_on_issue_id "
t . index [ " label_id " ] , name : " index_resource_label_events_on_label_id "
t . index [ " merge_request_id " ] , name : " index_resource_label_events_on_merge_request_id "
t . index [ " user_id " ] , name : " index_resource_label_events_on_user_id "
end
create_table " reviews " , force : :cascade do | t |
t . integer " author_id "
t . integer " merge_request_id " , null : false
t . integer " project_id " , null : false
t . datetime_with_timezone " created_at " , null : false
t . index [ " author_id " ] , name : " index_reviews_on_author_id "
t . index [ " merge_request_id " ] , name : " index_reviews_on_merge_request_id "
t . index [ " project_id " ] , name : " index_reviews_on_project_id "
2018-11-18 11:00:15 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " routes " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " source_id " , null : false
t . string " source_type " , null : false
t . string " path " , null : false
t . datetime " created_at "
t . datetime " updated_at "
t . string " name "
2019-12-16 22:33:55 +05:30
t . index [ " path " ] , name : " index_routes_on_path " , unique : true
t . index [ " path " ] , name : " index_routes_on_path_text_pattern_ops " , opclass : :varchar_pattern_ops
t . index [ " source_type " , " source_id " ] , name : " index_routes_on_source_type_and_source_id " , unique : true
end
create_table " saml_providers " , id : :serial , force : :cascade do | t |
t . integer " group_id " , null : false
t . boolean " enabled " , null : false
t . string " certificate_fingerprint " , null : false
t . string " sso_url " , null : false
t . boolean " enforced_sso " , default : false , null : false
t . boolean " enforced_group_managed_accounts " , default : false , null : false
t . index [ " group_id " ] , name : " index_saml_providers_on_group_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " scim_oauth_access_tokens " , id : :serial , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " group_id " , null : false
t . string " token_encrypted " , null : false
t . index [ " group_id " , " token_encrypted " ] , name : " index_scim_oauth_access_tokens_on_group_id_and_token_encrypted " , unique : true
end
create_table " sent_notifications " , id : :serial , force : :cascade do | t |
2015-09-25 12:07:36 +05:30
t . integer " project_id "
t . integer " noteable_id "
2016-11-03 12:29:30 +05:30
t . string " noteable_type "
2015-09-25 12:07:36 +05:30
t . integer " recipient_id "
2016-11-03 12:29:30 +05:30
t . string " commit_id "
t . string " reply_key " , null : false
t . string " line_code "
t . string " note_type "
t . text " position "
2017-08-17 22:00:37 +05:30
t . string " in_reply_to_discussion_id "
2019-12-16 22:33:55 +05:30
t . index [ " reply_key " ] , name : " index_sent_notifications_on_reply_key " , unique : true
2015-09-25 12:07:36 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " services " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " type "
t . string " title "
t . integer " project_id "
2016-06-02 11:05:42 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . boolean " active " , default : false , null : false
t . text " properties "
t . boolean " template " , default : false
t . boolean " push_events " , default : true
t . boolean " issues_events " , default : true
t . boolean " merge_requests_events " , default : true
t . boolean " tag_push_events " , default : true
t . boolean " note_events " , default : true , null : false
t . string " category " , default : " common " , null : false
t . boolean " default " , default : false
t . boolean " wiki_page_events " , default : true
t . boolean " pipeline_events " , default : false , null : false
t . boolean " confidential_issues_events " , default : true , null : false
2017-08-17 22:00:37 +05:30
t . boolean " commit_events " , default : true , null : false
2017-09-10 17:25:29 +05:30
t . boolean " job_events " , default : false , null : false
2018-04-05 14:03:07 +05:30
t . boolean " confidential_note_events " , default : true
2019-12-16 22:33:55 +05:30
t . boolean " deployment_events " , default : false , null : false
t . string " description " , limit : 500
t . index [ " project_id " ] , name : " index_services_on_project_id "
t . index [ " template " ] , name : " index_services_on_template "
t . index [ " type " ] , name : " index_services_on_type "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " shards " , id : :serial , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . string " name " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " name " ] , name : " index_shards_on_name " , unique : true
end
create_table " slack_integrations " , id : :serial , force : :cascade do | t |
t . integer " service_id " , null : false
t . string " team_id " , null : false
t . string " team_name " , null : false
t . string " alias " , null : false
t . string " user_id " , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . index [ " service_id " ] , name : " index_slack_integrations_on_service_id "
t . index [ " team_id " , " alias " ] , name : " index_slack_integrations_on_team_id_and_alias " , unique : true
end
create_table " smartcard_identities " , force : :cascade do | t |
t . integer " user_id " , null : false
t . string " subject " , null : false
t . string " issuer " , null : false
t . index [ " subject " , " issuer " ] , name : " index_smartcard_identities_on_subject_and_issuer " , unique : true
t . index [ " user_id " ] , name : " index_smartcard_identities_on_user_id "
2018-11-18 11:00:15 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " snippets " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " title "
t . text " content "
t . integer " author_id " , null : false
t . integer " project_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " file_name "
t . string " type "
t . integer " visibility_level " , default : 0 , null : false
t . text " title_html "
t . text " content_html "
2017-08-17 22:00:37 +05:30
t . integer " cached_markdown_version "
2017-09-10 17:25:29 +05:30
t . text " description "
t . text " description_html "
2019-12-16 22:33:55 +05:30
t . index [ " author_id " ] , name : " index_snippets_on_author_id "
t . index [ " file_name " ] , name : " index_snippets_on_file_name_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " project_id " ] , name : " index_snippets_on_project_id "
t . index [ " title " ] , name : " index_snippets_on_title_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " updated_at " ] , name : " index_snippets_on_updated_at "
t . index [ " visibility_level " ] , name : " index_snippets_on_visibility_level "
end
create_table " software_license_policies " , id : :serial , force : :cascade do | t |
t . integer " project_id " , null : false
t . integer " software_license_id " , null : false
t . integer " approval_status " , default : 0 , null : false
t . index [ " project_id " , " software_license_id " ] , name : " index_software_license_policies_unique_per_project " , unique : true
t . index [ " software_license_id " ] , name : " index_software_license_policies_on_software_license_id "
end
create_table " software_licenses " , id : :serial , force : :cascade do | t |
t . string " name " , null : false
t . index [ " name " ] , name : " index_software_licenses_on_name "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " spam_logs " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id "
t . string " source_ip "
t . string " user_agent "
t . boolean " via_api "
t . string " noteable_type "
t . string " title "
t . text " description "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . boolean " submitted_as_ham " , default : false , null : false
2017-08-17 22:00:37 +05:30
t . boolean " recaptcha_verified " , default : false , null : false
2016-04-02 18:10:28 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " subscriptions " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id "
t . integer " subscribable_id "
t . string " subscribable_type "
t . boolean " subscribed "
2015-04-26 12:48:37 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2017-08-17 22:00:37 +05:30
t . integer " project_id "
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_subscriptions_on_project_id "
t . index [ " subscribable_id " , " subscribable_type " , " user_id " , " project_id " ] , name : " index_subscriptions_on_subscribable_and_user_id_and_project_id " , unique : true
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " suggestions " , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . integer " note_id " , null : false
t . integer " relative_order " , limit : 2 , null : false
t . boolean " applied " , default : false , null : false
t . string " commit_id "
t . text " from_content " , null : false
t . text " to_content " , null : false
2019-12-16 22:33:55 +05:30
t . integer " lines_above " , default : 0 , null : false
t . integer " lines_below " , default : 0 , null : false
t . boolean " outdated " , default : false , null : false
t . index [ " note_id " , " relative_order " ] , name : " index_suggestions_on_note_id_and_relative_order " , unique : true
2019-02-15 15:39:39 +05:30
end
2017-08-17 22:00:37 +05:30
2019-12-16 22:33:55 +05:30
create_table " system_note_metadata " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " note_id " , null : false
t . integer " commit_count "
t . string " action "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " note_id " ] , name : " index_system_note_metadata_on_note_id " , unique : true
2015-04-26 12:48:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " taggings " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " tag_id "
t . integer " taggable_id "
t . string " taggable_type "
t . integer " tagger_id "
t . string " tagger_type "
t . string " context "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
2019-12-16 22:33:55 +05:30
t . index [ " tag_id " , " taggable_id " , " taggable_type " , " context " , " tagger_id " , " tagger_type " ] , name : " taggings_idx " , unique : true
t . index [ " tag_id " ] , name : " index_taggings_on_tag_id "
t . index [ " taggable_id " , " taggable_type " , " context " ] , name : " index_taggings_on_taggable_id_and_taggable_type_and_context "
t . index [ " taggable_id " , " taggable_type " ] , name : " index_taggings_on_taggable_id_and_taggable_type "
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " tags " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " name "
2016-01-19 16:12:03 +05:30
t . integer " taggings_count " , default : 0
2019-12-16 22:33:55 +05:30
t . index [ " name " ] , name : " index_tags_on_name " , unique : true
t . index [ " name " ] , name : " index_tags_on_name_trigram " , opclass : :gin_trgm_ops , using : :gin
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " term_agreements " , id : :serial , force : :cascade do | t |
2018-10-15 14:42:47 +05:30
t . integer " term_id " , null : false
t . integer " user_id " , null : false
t . boolean " accepted " , default : false , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " term_id " ] , name : " index_term_agreements_on_term_id "
t . index [ " user_id " , " term_id " ] , name : " term_agreements_unique_index " , unique : true
t . index [ " user_id " ] , name : " index_term_agreements_on_user_id "
2018-10-15 14:42:47 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " timelogs " , id : :serial , force : :cascade do | t |
2017-08-17 22:00:37 +05:30
t . integer " time_spent " , null : false
t . integer " user_id "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . integer " issue_id "
t . integer " merge_request_id "
2019-12-16 22:33:55 +05:30
t . datetime " spent_at "
t . index [ " issue_id " ] , name : " index_timelogs_on_issue_id "
t . index [ " merge_request_id " ] , name : " index_timelogs_on_merge_request_id "
t . index [ " user_id " ] , name : " index_timelogs_on_user_id "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " todos " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " user_id " , null : false
2018-11-18 11:00:15 +05:30
t . integer " project_id "
2016-11-03 12:29:30 +05:30
t . integer " target_id "
t . string " target_type " , null : false
2018-03-17 18:26:18 +05:30
t . integer " author_id " , null : false
2016-11-03 12:29:30 +05:30
t . integer " action " , null : false
t . string " state " , null : false
2016-04-02 18:10:28 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . integer " note_id "
t . string " commit_id "
2018-11-18 11:00:15 +05:30
t . integer " group_id "
2019-12-16 22:33:55 +05:30
t . index [ " author_id " ] , name : " index_todos_on_author_id "
t . index [ " commit_id " ] , name : " index_todos_on_commit_id "
t . index [ " group_id " ] , name : " index_todos_on_group_id "
t . index [ " note_id " ] , name : " index_todos_on_note_id "
t . index [ " project_id " ] , name : " index_todos_on_project_id "
t . index [ " target_type " , " target_id " ] , name : " index_todos_on_target_type_and_target_id "
t . index [ " user_id " , " id " ] , name : " index_todos_on_user_id_and_id_done " , where : " ((state)::text = 'done'::text) "
t . index [ " user_id " , " id " ] , name : " index_todos_on_user_id_and_id_pending " , where : " ((state)::text = 'pending'::text) "
t . index [ " user_id " ] , name : " index_todos_on_user_id "
end
create_table " trending_projects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " project_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_trending_projects_on_project_id " , unique : true
2016-11-03 12:29:30 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " u2f_registrations " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . text " certificate "
t . string " key_handle "
t . string " public_key "
t . integer " counter "
t . integer " user_id "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
t . string " name "
2019-12-16 22:33:55 +05:30
t . index [ " key_handle " ] , name : " index_u2f_registrations_on_key_handle "
t . index [ " user_id " ] , name : " index_u2f_registrations_on_user_id "
2016-06-16 23:09:34 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " uploads " , id : :serial , force : :cascade do | t |
2019-02-15 15:39:39 +05:30
t . bigint " size " , null : false
2018-03-17 18:26:18 +05:30
t . string " path " , limit : 511 , null : false
2017-08-17 22:00:37 +05:30
t . string " checksum " , limit : 64
t . integer " model_id "
t . string " model_type "
t . string " uploader " , null : false
t . datetime " created_at " , null : false
2019-12-16 22:33:55 +05:30
t . integer " store "
2018-03-17 18:26:18 +05:30
t . string " mount_point "
t . string " secret "
2019-12-16 22:33:55 +05:30
t . index [ " checksum " ] , name : " index_uploads_on_checksum "
t . index [ " model_id " , " model_type " ] , name : " index_uploads_on_model_id_and_model_type "
t . index [ " store " ] , name : " index_uploads_on_store "
t . index [ " uploader " , " path " ] , name : " index_uploads_on_uploader_and_path "
2017-08-17 22:00:37 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " user_agent_details " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " user_agent " , null : false
t . string " ip_address " , null : false
t . integer " subject_id " , null : false
t . string " subject_type " , null : false
t . boolean " submitted " , default : false , null : false
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " subject_id " , " subject_type " ] , name : " index_user_agent_details_on_subject_id_and_subject_type "
2016-09-13 17:45:13 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " user_callouts " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . integer " feature_name " , null : false
t . integer " user_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " user_id " , " feature_name " ] , name : " index_user_callouts_on_user_id_and_feature_name " , unique : true
t . index [ " user_id " ] , name : " index_user_callouts_on_user_id "
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " user_custom_attributes " , id : :serial , force : :cascade do | t |
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2018-03-17 18:26:18 +05:30
t . integer " user_id " , null : false
t . string " key " , null : false
t . string " value " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " key " , " value " ] , name : " index_user_custom_attributes_on_key_and_value "
t . index [ " user_id " , " key " ] , name : " index_user_custom_attributes_on_user_id_and_key " , unique : true
2018-03-17 18:26:18 +05:30
end
2018-03-27 19:54:05 +05:30
create_table " user_interacted_projects " , id : false , force : :cascade do | t |
t . integer " user_id " , null : false
t . integer " project_id " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " project_id " , " user_id " ] , name : " index_user_interacted_projects_on_project_id_and_user_id " , unique : true
t . index [ " user_id " ] , name : " index_user_interacted_projects_on_user_id "
2018-03-27 19:54:05 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " user_preferences " , id : :serial , force : :cascade do | t |
2018-12-13 13:39:08 +05:30
t . integer " user_id " , null : false
t . integer " issue_notes_filter " , limit : 2 , default : 0 , null : false
t . integer " merge_request_notes_filter " , limit : 2 , default : 0 , null : false
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . string " epics_sort "
t . integer " roadmap_epics_state "
t . integer " epic_notes_filter " , limit : 2 , default : 0 , null : false
2019-03-02 22:35:43 +05:30
t . string " issues_sort "
t . string " merge_requests_sort "
2019-12-16 22:33:55 +05:30
t . string " roadmaps_sort "
t . integer " first_day_of_week "
t . string " timezone "
t . boolean " time_display_relative "
t . boolean " time_format_in_24h "
t . string " projects_sort " , limit : 64
t . boolean " show_whitespace_in_diffs " , default : true , null : false
t . index [ " user_id " ] , name : " index_user_preferences_on_user_id " , unique : true
2018-12-13 13:39:08 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " user_statuses " , primary_key : " user_id " , id : :serial , force : :cascade do | t |
2018-11-18 11:00:15 +05:30
t . integer " cached_markdown_version "
t . string " emoji " , default : " speech_balloon " , null : false
t . string " message " , limit : 100
t . string " message_html "
2019-12-16 22:33:55 +05:30
t . index [ " user_id " ] , name : " index_user_statuses_on_user_id "
2018-11-18 11:00:15 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " user_synced_attributes_metadata " , id : :serial , force : :cascade do | t |
2018-03-17 18:26:18 +05:30
t . boolean " name_synced " , default : false
t . boolean " email_synced " , default : false
t . boolean " location_synced " , default : false
t . integer " user_id " , null : false
t . string " provider "
2019-12-16 22:33:55 +05:30
t . index [ " user_id " ] , name : " index_user_synced_attributes_metadata_on_user_id " , unique : true
2018-03-17 18:26:18 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " users " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . string " email " , default : " " , null : false
t . string " encrypted_password " , default : " " , null : false
t . string " reset_password_token "
2014-09-02 18:07:02 +05:30
t . datetime " reset_password_sent_at "
t . datetime " remember_created_at "
2016-11-03 12:29:30 +05:30
t . integer " sign_in_count " , default : 0
2014-09-02 18:07:02 +05:30
t . datetime " current_sign_in_at "
t . datetime " last_sign_in_at "
2016-11-03 12:29:30 +05:30
t . string " current_sign_in_ip "
t . string " last_sign_in_ip "
2016-01-19 16:12:03 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " name "
t . boolean " admin " , default : false , null : false
2018-03-17 18:26:18 +05:30
t . integer " projects_limit " , null : false
2016-11-03 12:29:30 +05:30
t . string " skype " , default : " " , null : false
t . string " linkedin " , default : " " , null : false
t . string " twitter " , default : " " , null : false
t . string " bio "
t . integer " failed_attempts " , default : 0
2014-09-02 18:07:02 +05:30
t . datetime " locked_at "
2016-11-03 12:29:30 +05:30
t . string " username "
t . boolean " can_create_group " , default : true , null : false
t . boolean " can_create_team " , default : true , null : false
t . string " state "
t . integer " color_scheme_id " , default : 1 , null : false
2014-09-02 18:07:02 +05:30
t . datetime " password_expires_at "
2016-11-03 12:29:30 +05:30
t . integer " created_by_id "
2015-04-26 12:48:37 +05:30
t . datetime " last_credential_check_at "
2016-11-03 12:29:30 +05:30
t . string " avatar "
t . string " confirmation_token "
2014-09-02 18:07:02 +05:30
t . datetime " confirmed_at "
t . datetime " confirmation_sent_at "
2016-11-03 12:29:30 +05:30
t . string " unconfirmed_email "
t . boolean " hide_no_ssh_key " , default : false
t . string " website_url " , default : " " , null : false
2019-12-16 22:33:55 +05:30
t . datetime " admin_email_unsubscribed_at "
2016-11-03 12:29:30 +05:30
t . string " notification_email "
t . boolean " hide_no_password " , default : false
t . boolean " password_automatically_set " , default : false
t . string " location "
t . string " encrypted_otp_secret "
t . string " encrypted_otp_secret_iv "
t . string " encrypted_otp_secret_salt "
t . boolean " otp_required_for_login " , default : false , null : false
t . text " otp_backup_codes "
t . string " public_email " , default : " " , null : false
t . integer " dashboard " , default : 0
t . integer " project_view " , default : 0
t . integer " consumed_timestep "
t . integer " layout " , default : 0
t . boolean " hide_project_limit " , default : false
2019-12-16 22:33:55 +05:30
t . text " note "
2016-11-03 12:29:30 +05:30
t . string " unlock_token "
2016-01-14 18:37:52 +05:30
t . datetime " otp_grace_period_started_at "
2016-11-03 12:29:30 +05:30
t . boolean " external " , default : false
2017-08-17 22:00:37 +05:30
t . string " incoming_email_token "
2016-11-03 12:29:30 +05:30
t . string " organization "
2019-12-16 22:33:55 +05:30
t . boolean " auditor " , default : false , null : false
2017-08-17 22:00:37 +05:30
t . boolean " require_two_factor_authentication_from_group " , default : false , null : false
t . integer " two_factor_grace_period " , default : 48 , null : false
t . boolean " ghost "
t . date " last_activity_on "
t . boolean " notified_of_own_activity "
t . string " preferred_language "
2019-12-16 22:33:55 +05:30
t . boolean " email_opted_in "
t . string " email_opted_in_ip "
t . integer " email_opted_in_source_id "
t . datetime " email_opted_in_at "
2018-03-17 18:26:18 +05:30
t . integer " theme_id " , limit : 2
2018-10-15 14:42:47 +05:30
t . integer " accepted_term_id "
2018-11-08 19:23:39 +05:30
t . string " feed_token "
2019-12-16 22:33:55 +05:30
t . boolean " private_profile " , default : false , null : false
t . integer " roadmap_layout " , limit : 2
2018-11-20 20:47:30 +05:30
t . boolean " include_private_contributions "
2018-12-05 23:21:45 +05:30
t . string " commit_email "
2019-12-16 22:33:55 +05:30
t . integer " group_view "
t . integer " managing_group_id "
t . integer " bot_type " , limit : 2
t . string " first_name " , limit : 255
t . string " last_name " , limit : 255
t . string " static_object_token " , limit : 255
t . index [ " accepted_term_id " ] , name : " index_users_on_accepted_term_id "
t . index [ " admin " ] , name : " index_users_on_admin "
t . index [ " bot_type " ] , name : " index_users_on_bot_type "
t . index [ " confirmation_token " ] , name : " index_users_on_confirmation_token " , unique : true
t . index [ " created_at " ] , name : " index_users_on_created_at "
t . index [ " email " ] , name : " index_users_on_email " , unique : true
t . index [ " email " ] , name : " index_users_on_email_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " feed_token " ] , name : " index_users_on_feed_token "
t . index [ " ghost " ] , name : " index_users_on_ghost "
t . index [ " group_view " ] , name : " index_users_on_group_view "
t . index [ " incoming_email_token " ] , name : " index_users_on_incoming_email_token "
t . index [ " managing_group_id " ] , name : " index_users_on_managing_group_id "
t . index [ " name " ] , name : " index_users_on_name "
t . index [ " name " ] , name : " index_users_on_name_trigram " , opclass : :gin_trgm_ops , using : :gin
t . index [ " public_email " ] , name : " index_users_on_public_email " , where : " ((public_email)::text <> ''::text) "
t . index [ " reset_password_token " ] , name : " index_users_on_reset_password_token " , unique : true
t . index [ " state " ] , name : " index_users_on_state "
t . index [ " state " ] , name : " index_users_on_state_and_internal " , where : " (ghost IS NOT TRUE) "
t . index [ " state " ] , name : " index_users_on_state_and_internal_ee " , where : " ((ghost IS NOT TRUE) AND (bot_type IS NULL)) "
t . index [ " static_object_token " ] , name : " index_users_on_static_object_token " , unique : true
t . index [ " unconfirmed_email " ] , name : " index_users_on_unconfirmed_email " , where : " (unconfirmed_email IS NOT NULL) "
t . index [ " username " ] , name : " index_users_on_username "
t . index [ " username " ] , name : " index_users_on_username_trigram " , opclass : :gin_trgm_ops , using : :gin
end
create_table " users_ops_dashboard_projects " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " user_id " , null : false
t . integer " project_id " , null : false
t . index [ " project_id " ] , name : " index_users_ops_dashboard_projects_on_project_id "
t . index [ " user_id " , " project_id " ] , name : " index_users_ops_dashboard_projects_on_user_id_and_project_id " , unique : true
end
create_table " users_star_projects " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " project_id " , null : false
t . integer " user_id " , null : false
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_users_star_projects_on_project_id "
t . index [ " user_id " , " project_id " ] , name : " index_users_star_projects_on_user_id_and_project_id " , unique : true
end
create_table " vulnerability_feedback " , id : :serial , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " feedback_type " , limit : 2 , null : false
t . integer " category " , limit : 2 , null : false
t . integer " project_id " , null : false
t . integer " author_id " , null : false
t . integer " pipeline_id "
t . integer " issue_id "
t . string " project_fingerprint " , limit : 40 , null : false
t . integer " merge_request_id "
t . integer " comment_author_id "
t . text " comment "
t . datetime_with_timezone " comment_timestamp "
t . index [ " author_id " ] , name : " index_vulnerability_feedback_on_author_id "
t . index [ " comment_author_id " ] , name : " index_vulnerability_feedback_on_comment_author_id "
t . index [ " issue_id " ] , name : " index_vulnerability_feedback_on_issue_id "
t . index [ " merge_request_id " ] , name : " index_vulnerability_feedback_on_merge_request_id "
t . index [ " pipeline_id " ] , name : " index_vulnerability_feedback_on_pipeline_id "
t . index [ " project_id " , " category " , " feedback_type " , " project_fingerprint " ] , name : " vulnerability_feedback_unique_idx " , unique : true
end
create_table " vulnerability_identifiers " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " project_id " , null : false
t . binary " fingerprint " , null : false
t . string " external_type " , null : false
t . string " external_id " , null : false
t . string " name " , null : false
t . text " url "
t . index [ " project_id " , " fingerprint " ] , name : " index_vulnerability_identifiers_on_project_id_and_fingerprint " , unique : true
end
create_table " vulnerability_occurrence_identifiers " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . bigint " occurrence_id " , null : false
t . bigint " identifier_id " , null : false
t . index [ " identifier_id " ] , name : " index_vulnerability_occurrence_identifiers_on_identifier_id "
t . index [ " occurrence_id " , " identifier_id " ] , name : " index_vulnerability_occurrence_identifiers_on_unique_keys " , unique : true
end
create_table " vulnerability_occurrence_pipelines " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . bigint " occurrence_id " , null : false
t . integer " pipeline_id " , null : false
t . index [ " occurrence_id " , " pipeline_id " ] , name : " vulnerability_occurrence_pipelines_on_unique_keys " , unique : true
t . index [ " pipeline_id " ] , name : " index_vulnerability_occurrence_pipelines_on_pipeline_id "
end
create_table " vulnerability_occurrences " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " severity " , limit : 2 , null : false
t . integer " confidence " , limit : 2 , null : false
t . integer " report_type " , limit : 2 , null : false
t . integer " project_id " , null : false
t . bigint " scanner_id " , null : false
t . bigint " primary_identifier_id " , null : false
t . binary " project_fingerprint " , null : false
t . binary " location_fingerprint " , null : false
t . string " uuid " , limit : 36 , null : false
t . string " name " , null : false
t . string " metadata_version " , null : false
t . text " raw_metadata " , null : false
t . index [ " primary_identifier_id " ] , name : " index_vulnerability_occurrences_on_primary_identifier_id "
t . index [ " project_id " , " primary_identifier_id " , " location_fingerprint " , " scanner_id " ] , name : " index_vulnerability_occurrences_on_unique_keys " , unique : true
t . index [ " scanner_id " ] , name : " index_vulnerability_occurrences_on_scanner_id "
t . index [ " uuid " ] , name : " index_vulnerability_occurrences_on_uuid " , unique : true
end
create_table " vulnerability_scanners " , force : :cascade do | t |
t . datetime_with_timezone " created_at " , null : false
t . datetime_with_timezone " updated_at " , null : false
t . integer " project_id " , null : false
t . string " external_id " , null : false
t . string " name " , null : false
t . index [ " project_id " , " external_id " ] , name : " index_vulnerability_scanners_on_project_id_and_external_id " , unique : true
2014-09-02 18:07:02 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " web_hook_logs " , id : :serial , force : :cascade do | t |
2017-09-10 17:25:29 +05:30
t . integer " web_hook_id " , null : false
t . string " trigger "
t . string " url "
t . text " request_headers "
t . text " request_data "
t . text " response_headers "
t . text " response_body "
t . string " response_status "
t . float " execution_duration "
t . string " internal_error_message "
t . datetime " created_at " , null : false
t . datetime " updated_at " , null : false
2019-12-16 22:33:55 +05:30
t . index [ " created_at " , " web_hook_id " ] , name : " index_web_hook_logs_on_created_at_and_web_hook_id "
t . index [ " web_hook_id " ] , name : " index_web_hook_logs_on_web_hook_id "
2017-09-10 17:25:29 +05:30
end
2019-12-16 22:33:55 +05:30
create_table " web_hooks " , id : :serial , force : :cascade do | t |
2016-11-03 12:29:30 +05:30
t . integer " project_id "
2014-09-02 18:07:02 +05:30
t . datetime " created_at "
t . datetime " updated_at "
2016-11-03 12:29:30 +05:30
t . string " type " , default : " ProjectHook "
t . integer " service_id "
t . boolean " push_events " , default : true , null : false
t . boolean " issues_events " , default : false , null : false
t . boolean " merge_requests_events " , default : false , null : false
t . boolean " tag_push_events " , default : false
2019-12-16 22:33:55 +05:30
t . integer " group_id "
2016-11-03 12:29:30 +05:30
t . boolean " note_events " , default : false , null : false
t . boolean " enable_ssl_verification " , default : true
t . boolean " wiki_page_events " , default : false , null : false
t . boolean " pipeline_events " , default : false , null : false
t . boolean " confidential_issues_events " , default : false , null : false
2017-09-10 17:25:29 +05:30
t . boolean " repository_update_events " , default : false , null : false
t . boolean " job_events " , default : false , null : false
2018-04-05 14:03:07 +05:30
t . boolean " confidential_note_events "
2018-11-20 20:47:30 +05:30
t . text " push_events_branch_filter "
2018-12-05 23:21:45 +05:30
t . string " encrypted_token "
t . string " encrypted_token_iv "
t . string " encrypted_url "
t . string " encrypted_url_iv "
2019-12-16 22:33:55 +05:30
t . index [ " project_id " ] , name : " index_web_hooks_on_project_id "
t . index [ " type " ] , name : " index_web_hooks_on_type "
end
add_foreign_key " alerts_service_data " , " services " , on_delete : :cascade
add_foreign_key " allowed_email_domains " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " analytics_cycle_analytics_group_stages " , " labels " , column : " end_event_label_id " , on_delete : :cascade
add_foreign_key " analytics_cycle_analytics_group_stages " , " labels " , column : " start_event_label_id " , on_delete : :cascade
add_foreign_key " analytics_cycle_analytics_group_stages " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " analytics_cycle_analytics_project_stages " , " labels " , column : " end_event_label_id " , on_delete : :cascade
add_foreign_key " analytics_cycle_analytics_project_stages " , " labels " , column : " start_event_label_id " , on_delete : :cascade
add_foreign_key " analytics_cycle_analytics_project_stages " , " projects " , on_delete : :cascade
add_foreign_key " analytics_language_trend_repository_languages " , " programming_languages " , on_delete : :cascade
add_foreign_key " analytics_language_trend_repository_languages " , " projects " , on_delete : :cascade
add_foreign_key " application_settings " , " namespaces " , column : " custom_project_templates_group_id " , on_delete : :nullify
add_foreign_key " application_settings " , " projects " , column : " file_template_project_id " , name : " fk_ec757bd087 " , on_delete : :nullify
add_foreign_key " application_settings " , " projects " , column : " instance_administration_project_id " , on_delete : :nullify
2018-11-20 20:47:30 +05:30
add_foreign_key " application_settings " , " users " , column : " usage_stats_set_by_user_id " , name : " fk_964370041d " , on_delete : :nullify
2019-12-16 22:33:55 +05:30
add_foreign_key " approval_merge_request_rule_sources " , " approval_merge_request_rules " , on_delete : :cascade
add_foreign_key " approval_merge_request_rule_sources " , " approval_project_rules " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules " , " merge_requests " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules_approved_approvers " , " approval_merge_request_rules " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules_approved_approvers " , " users " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules_groups " , " approval_merge_request_rules " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules_groups " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules_users " , " approval_merge_request_rules " , on_delete : :cascade
add_foreign_key " approval_merge_request_rules_users " , " users " , on_delete : :cascade
add_foreign_key " approval_project_rules " , " projects " , on_delete : :cascade
add_foreign_key " approval_project_rules_groups " , " approval_project_rules " , on_delete : :cascade
add_foreign_key " approval_project_rules_groups " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " approval_project_rules_users " , " approval_project_rules " , on_delete : :cascade
add_foreign_key " approval_project_rules_users " , " users " , on_delete : :cascade
add_foreign_key " approvals " , " merge_requests " , name : " fk_310d714958 " , on_delete : :cascade
add_foreign_key " approver_groups " , " namespaces " , column : " group_id " , on_delete : :cascade
2018-03-27 19:54:05 +05:30
add_foreign_key " badges " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " badges " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " board_assignees " , " boards " , on_delete : :cascade
add_foreign_key " board_assignees " , " users " , column : " assignee_id " , on_delete : :cascade
2018-12-13 13:39:08 +05:30
add_foreign_key " board_group_recent_visits " , " boards " , on_delete : :cascade
add_foreign_key " board_group_recent_visits " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " board_group_recent_visits " , " users " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " board_labels " , " boards " , on_delete : :cascade
add_foreign_key " board_labels " , " labels " , on_delete : :cascade
2018-12-13 13:39:08 +05:30
add_foreign_key " board_project_recent_visits " , " boards " , on_delete : :cascade
add_foreign_key " board_project_recent_visits " , " projects " , on_delete : :cascade
add_foreign_key " board_project_recent_visits " , " users " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " boards " , " namespaces " , column : " group_id " , name : " fk_1e9a074a35 " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " boards " , " projects " , name : " fk_f15266b5f9 " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " chat_teams " , " namespaces " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " ci_build_needs " , " ci_builds " , column : " build_id " , on_delete : :cascade
2018-10-15 14:42:47 +05:30
add_foreign_key " ci_build_trace_chunks " , " ci_builds " , column : " build_id " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " ci_build_trace_section_names " , " projects " , on_delete : :cascade
add_foreign_key " ci_build_trace_sections " , " ci_build_trace_section_names " , column : " section_name_id " , name : " fk_264e112c66 " , on_delete : :cascade
add_foreign_key " ci_build_trace_sections " , " ci_builds " , column : " build_id " , name : " fk_4ebe41f502 " , on_delete : :cascade
add_foreign_key " ci_build_trace_sections " , " projects " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " ci_builds " , " ci_pipelines " , column : " auto_canceled_by_id " , name : " fk_a2141b1522 " , on_delete : :nullify
2018-10-15 14:42:47 +05:30
add_foreign_key " ci_builds " , " ci_pipelines " , column : " commit_id " , name : " fk_d3130c9a7f " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " ci_builds " , " ci_pipelines " , column : " upstream_pipeline_id " , name : " fk_87f4cefcda " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_builds " , " ci_stages " , column : " stage_id " , name : " fk_3a9eaa254d " , on_delete : :cascade
add_foreign_key " ci_builds " , " projects " , name : " fk_befce0568a " , on_delete : :cascade
2018-05-09 12:01:36 +05:30
add_foreign_key " ci_builds_metadata " , " ci_builds " , column : " build_id " , on_delete : :cascade
add_foreign_key " ci_builds_metadata " , " projects " , on_delete : :cascade
2018-11-08 19:23:39 +05:30
add_foreign_key " ci_builds_runner_session " , " ci_builds " , column : " build_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_group_variables " , " namespaces " , column : " group_id " , name : " fk_33ae4d58d8 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " ci_job_artifacts " , " ci_builds " , column : " job_id " , on_delete : :cascade
add_foreign_key " ci_job_artifacts " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " ci_job_variables " , " ci_builds " , column : " job_id " , on_delete : :cascade
add_foreign_key " ci_pipeline_chat_data " , " chat_names " , on_delete : :cascade
add_foreign_key " ci_pipeline_chat_data " , " ci_pipelines " , column : " pipeline_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_pipeline_schedule_variables " , " ci_pipeline_schedules " , column : " pipeline_schedule_id " , name : " fk_41c35fda51 " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " ci_pipeline_schedules " , " projects " , name : " fk_8ead60fcc4 " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_pipeline_schedules " , " users " , column : " owner_id " , name : " fk_9ea99f58d2 " , on_delete : :nullify
add_foreign_key " ci_pipeline_variables " , " ci_pipelines " , column : " pipeline_id " , name : " fk_f29c5f4380 " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " ci_pipelines " , " ci_pipeline_schedules " , column : " pipeline_schedule_id " , name : " fk_3d34ab2e06 " , on_delete : :nullify
add_foreign_key " ci_pipelines " , " ci_pipelines " , column : " auto_canceled_by_id " , name : " fk_262d4c2d19 " , on_delete : :nullify
2019-12-16 22:33:55 +05:30
add_foreign_key " ci_pipelines " , " external_pull_requests " , name : " fk_190998ef09 " , on_delete : :nullify
2019-02-15 15:39:39 +05:30
add_foreign_key " ci_pipelines " , " merge_requests " , name : " fk_a23be95014 " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_pipelines " , " projects " , name : " fk_86635dbd80 " , on_delete : :cascade
2018-10-15 14:42:47 +05:30
add_foreign_key " ci_runner_namespaces " , " ci_runners " , column : " runner_id " , on_delete : :cascade
add_foreign_key " ci_runner_namespaces " , " namespaces " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_runner_projects " , " projects " , name : " fk_4478a6f1e4 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " ci_sources_pipelines " , " ci_builds " , column : " source_job_id " , name : " fk_be5624bf37 " , on_delete : :cascade
add_foreign_key " ci_sources_pipelines " , " ci_pipelines " , column : " pipeline_id " , name : " fk_e1bad85861 " , on_delete : :cascade
add_foreign_key " ci_sources_pipelines " , " ci_pipelines " , column : " source_pipeline_id " , name : " fk_d4e29af7d7 " , on_delete : :cascade
add_foreign_key " ci_sources_pipelines " , " projects " , column : " source_project_id " , name : " fk_acd9737679 " , on_delete : :cascade
add_foreign_key " ci_sources_pipelines " , " projects " , name : " fk_1e53c97c0a " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_stages " , " ci_pipelines " , column : " pipeline_id " , name : " fk_fb57e6cc56 " , on_delete : :cascade
add_foreign_key " ci_stages " , " projects " , name : " fk_2360681d1d " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " ci_trigger_requests " , " ci_triggers " , column : " trigger_id " , name : " fk_b8ec8b7245 " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_triggers " , " projects " , name : " fk_e3e63f966e " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " ci_triggers " , " users " , column : " owner_id " , name : " fk_e8e10d1964 " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " ci_variables " , " projects " , name : " fk_ada5eb64b3 " , on_delete : :cascade
2018-12-13 13:39:08 +05:30
add_foreign_key " cluster_groups " , " clusters " , on_delete : :cascade
add_foreign_key " cluster_groups " , " namespaces " , column : " group_id " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " cluster_platforms_kubernetes " , " clusters " , on_delete : :cascade
add_foreign_key " cluster_projects " , " clusters " , on_delete : :cascade
add_foreign_key " cluster_projects " , " projects " , on_delete : :cascade
add_foreign_key " cluster_providers_gcp " , " clusters " , on_delete : :cascade
add_foreign_key " clusters " , " users " , on_delete : :nullify
2019-02-15 15:39:39 +05:30
add_foreign_key " clusters_applications_cert_managers " , " clusters " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " clusters_applications_helm " , " clusters " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " clusters_applications_ingress " , " clusters " , on_delete : :cascade
2018-11-08 19:23:39 +05:30
add_foreign_key " clusters_applications_jupyter " , " clusters " , on_delete : :cascade
add_foreign_key " clusters_applications_jupyter " , " oauth_applications " , on_delete : :nullify
2018-12-13 13:39:08 +05:30
add_foreign_key " clusters_applications_knative " , " clusters " , on_delete : :cascade
2018-03-27 19:54:05 +05:30
add_foreign_key " clusters_applications_prometheus " , " clusters " , name : " fk_557e773639 " , on_delete : :cascade
add_foreign_key " clusters_applications_runners " , " ci_runners " , column : " runner_id " , name : " fk_02de2ded36 " , on_delete : :nullify
add_foreign_key " clusters_applications_runners " , " clusters " , on_delete : :cascade
2018-12-13 13:39:08 +05:30
add_foreign_key " clusters_kubernetes_namespaces " , " cluster_projects " , on_delete : :nullify
add_foreign_key " clusters_kubernetes_namespaces " , " clusters " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " clusters_kubernetes_namespaces " , " environments " , on_delete : :nullify
2018-12-13 13:39:08 +05:30
add_foreign_key " clusters_kubernetes_namespaces " , " projects " , on_delete : :nullify
2017-08-17 22:00:37 +05:30
add_foreign_key " container_repositories " , " projects "
2019-12-16 22:33:55 +05:30
add_foreign_key " dependency_proxy_blobs " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " dependency_proxy_group_settings " , " namespaces " , column : " group_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " deploy_keys_projects " , " projects " , name : " fk_58a901ca7e " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " deployments " , " clusters " , name : " fk_289bba3222 " , on_delete : :nullify
2017-09-10 17:25:29 +05:30
add_foreign_key " deployments " , " projects " , name : " fk_b9a3851b82 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " design_management_designs " , " issues " , on_delete : :cascade
add_foreign_key " design_management_designs " , " projects " , on_delete : :cascade
add_foreign_key " design_management_designs_versions " , " design_management_designs " , column : " design_id " , name : " fk_03c671965c " , on_delete : :cascade
add_foreign_key " design_management_designs_versions " , " design_management_versions " , column : " version_id " , name : " fk_f4d25ba00c " , on_delete : :cascade
add_foreign_key " design_management_versions " , " issues " , on_delete : :cascade
add_foreign_key " draft_notes " , " merge_requests " , on_delete : :cascade
add_foreign_key " draft_notes " , " users " , column : " author_id " , on_delete : :cascade
add_foreign_key " elasticsearch_indexed_namespaces " , " namespaces " , on_delete : :cascade
add_foreign_key " elasticsearch_indexed_projects " , " projects " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " environments " , " projects " , name : " fk_d1c8c1da6a " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " epic_issues " , " epics " , on_delete : :cascade
add_foreign_key " epic_issues " , " issues " , on_delete : :cascade
add_foreign_key " epic_metrics " , " epics " , on_delete : :cascade
add_foreign_key " epics " , " epics " , column : " parent_id " , name : " fk_25b99c1be3 " , on_delete : :cascade
add_foreign_key " epics " , " milestones " , on_delete : :nullify
add_foreign_key " epics " , " namespaces " , column : " group_id " , name : " fk_f081aa4489 " , on_delete : :cascade
add_foreign_key " epics " , " users " , column : " assignee_id " , name : " fk_dccd3f98fc " , on_delete : :nullify
add_foreign_key " epics " , " users " , column : " author_id " , name : " fk_3654b61b03 " , on_delete : :cascade
add_foreign_key " epics " , " users " , column : " closed_by_id " , name : " fk_aa5798e761 " , on_delete : :nullify
add_foreign_key " events " , " namespaces " , column : " group_id " , name : " fk_61fbf6ca48 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " events " , " projects " , on_delete : :cascade
add_foreign_key " events " , " users " , column : " author_id " , name : " fk_edfd187b6f " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " external_pull_requests " , " projects " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " fork_network_members " , " fork_networks " , on_delete : :cascade
add_foreign_key " fork_network_members " , " projects " , column : " forked_from_project_id " , name : " fk_b01280dae4 " , on_delete : :nullify
add_foreign_key " fork_network_members " , " projects " , on_delete : :cascade
add_foreign_key " fork_networks " , " projects " , column : " root_project_id " , name : " fk_e7b436b2b5 " , on_delete : :nullify
2017-09-10 17:25:29 +05:30
add_foreign_key " forked_project_links " , " projects " , column : " forked_to_project_id " , name : " fk_434510edb0 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " geo_container_repository_updated_events " , " container_repositories " , name : " fk_212c89c706 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_cache_invalidation_events " , column : " cache_invalidation_event_id " , name : " fk_42c3b54bed " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_container_repository_updated_events " , column : " container_repository_updated_event_id " , name : " fk_6ada82d42a " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_hashed_storage_migrated_events " , column : " hashed_storage_migrated_event_id " , name : " fk_27548c6db3 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_job_artifact_deleted_events " , column : " job_artifact_deleted_event_id " , name : " fk_176d3fbb5d " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_lfs_object_deleted_events " , column : " lfs_object_deleted_event_id " , name : " fk_d5af95fcd9 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_repositories_changed_events " , column : " repositories_changed_event_id " , name : " fk_4a99ebfd60 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_repository_created_events " , column : " repository_created_event_id " , name : " fk_9b9afb1916 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_repository_deleted_events " , column : " repository_deleted_event_id " , name : " fk_c4b1c1f66e " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_repository_renamed_events " , column : " repository_renamed_event_id " , name : " fk_86c84214ec " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_repository_updated_events " , column : " repository_updated_event_id " , name : " fk_78a6492f68 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_reset_checksum_events " , column : " reset_checksum_event_id " , name : " fk_cff7185ad2 " , on_delete : :cascade
add_foreign_key " geo_event_log " , " geo_upload_deleted_events " , column : " upload_deleted_event_id " , name : " fk_c1f241c70d " , on_delete : :cascade
add_foreign_key " geo_hashed_storage_attachments_events " , " projects " , on_delete : :cascade
add_foreign_key " geo_hashed_storage_migrated_events " , " projects " , on_delete : :cascade
add_foreign_key " geo_node_namespace_links " , " geo_nodes " , on_delete : :cascade
add_foreign_key " geo_node_namespace_links " , " namespaces " , on_delete : :cascade
add_foreign_key " geo_node_statuses " , " geo_nodes " , on_delete : :cascade
add_foreign_key " geo_repositories_changed_events " , " geo_nodes " , on_delete : :cascade
add_foreign_key " geo_repository_created_events " , " projects " , on_delete : :cascade
add_foreign_key " geo_repository_renamed_events " , " projects " , on_delete : :cascade
add_foreign_key " geo_repository_updated_events " , " projects " , on_delete : :cascade
add_foreign_key " geo_reset_checksum_events " , " projects " , on_delete : :cascade
add_foreign_key " gitlab_subscriptions " , " namespaces " , name : " fk_e2595d00a1 " , on_delete : :cascade
add_foreign_key " gitlab_subscriptions " , " plans " , column : " hosted_plan_id " , name : " fk_bd0c4019c3 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " gpg_key_subkeys " , " gpg_keys " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " gpg_keys " , " users " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " gpg_signatures " , " gpg_key_subkeys " , on_delete : :nullify
2017-09-10 17:25:29 +05:30
add_foreign_key " gpg_signatures " , " gpg_keys " , on_delete : :nullify
add_foreign_key " gpg_signatures " , " projects " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " group_custom_attributes " , " namespaces " , column : " group_id " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " identities " , " saml_providers " , name : " fk_aade90f0fc " , on_delete : :cascade
2018-11-08 19:23:39 +05:30
add_foreign_key " import_export_uploads " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " index_statuses " , " projects " , name : " fk_74b2492545 " , on_delete : :cascade
add_foreign_key " insights " , " namespaces " , on_delete : :cascade
add_foreign_key " insights " , " projects " , on_delete : :cascade
2018-10-15 14:42:47 +05:30
add_foreign_key " internal_ids " , " namespaces " , name : " fk_162941d509 " , on_delete : :cascade
2018-05-09 12:01:36 +05:30
add_foreign_key " internal_ids " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " ip_restrictions " , " namespaces " , column : " group_id " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " issue_assignees " , " issues " , name : " fk_b7d881734a " , on_delete : :cascade
add_foreign_key " issue_assignees " , " users " , name : " fk_5e0c8d9154 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " issue_links " , " issues " , column : " source_id " , name : " fk_c900194ff2 " , on_delete : :cascade
add_foreign_key " issue_links " , " issues " , column : " target_id " , name : " fk_e71bb44f1f " , on_delete : :cascade
2016-09-29 09:46:39 +05:30
add_foreign_key " issue_metrics " , " issues " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " issue_tracker_data " , " services " , on_delete : :cascade
add_foreign_key " issues " , " issues " , column : " duplicated_to_id " , name : " fk_9c4516d665 " , on_delete : :nullify
2018-03-17 18:26:18 +05:30
add_foreign_key " issues " , " issues " , column : " moved_to_id " , name : " fk_a194299be1 " , on_delete : :nullify
add_foreign_key " issues " , " milestones " , name : " fk_96b1dd429c " , on_delete : :nullify
2017-09-10 17:25:29 +05:30
add_foreign_key " issues " , " projects " , name : " fk_899c8f3231 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " issues " , " users " , column : " author_id " , name : " fk_05f1e72feb " , on_delete : :nullify
2018-05-09 12:01:36 +05:30
add_foreign_key " issues " , " users " , column : " closed_by_id " , name : " fk_c63cbf6c25 " , on_delete : :nullify
2018-03-17 18:26:18 +05:30
add_foreign_key " issues " , " users " , column : " updated_by_id " , name : " fk_ffed080f01 " , on_delete : :nullify
2019-12-16 22:33:55 +05:30
add_foreign_key " jira_connect_subscriptions " , " jira_connect_installations " , on_delete : :cascade
add_foreign_key " jira_connect_subscriptions " , " namespaces " , on_delete : :cascade
add_foreign_key " jira_tracker_data " , " services " , on_delete : :cascade
2018-11-20 20:47:30 +05:30
add_foreign_key " label_links " , " labels " , name : " fk_d97dd08678 " , on_delete : :cascade
2016-11-03 12:29:30 +05:30
add_foreign_key " label_priorities " , " labels " , on_delete : :cascade
add_foreign_key " label_priorities " , " projects " , on_delete : :cascade
add_foreign_key " labels " , " namespaces " , column : " group_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " labels " , " projects " , name : " fk_7de4989a69 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " lfs_file_locks " , " projects " , on_delete : :cascade
add_foreign_key " lfs_file_locks " , " users " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " list_user_preferences " , " lists " , on_delete : :cascade
add_foreign_key " list_user_preferences " , " users " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " lists " , " boards " , name : " fk_0d3f677137 " , on_delete : :cascade
add_foreign_key " lists " , " labels " , name : " fk_7a5553d60f " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " lists " , " milestones " , on_delete : :cascade
add_foreign_key " lists " , " users " , name : " fk_d6cf4279f7 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " members " , " users " , name : " fk_2e88fb7ce9 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " merge_request_assignees " , " merge_requests " , on_delete : :cascade
add_foreign_key " merge_request_assignees " , " users " , on_delete : :cascade
add_foreign_key " merge_request_blocks " , " merge_requests " , column : " blocked_merge_request_id " , on_delete : :cascade
add_foreign_key " merge_request_blocks " , " merge_requests " , column : " blocking_merge_request_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " merge_request_diff_commits " , " merge_request_diffs " , on_delete : :cascade
add_foreign_key " merge_request_diff_files " , " merge_request_diffs " , on_delete : :cascade
add_foreign_key " merge_request_diffs " , " merge_requests " , name : " fk_8483f3258f " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " merge_request_metrics " , " ci_pipelines " , column : " pipeline_id " , on_delete : :cascade
2016-09-29 09:46:39 +05:30
add_foreign_key " merge_request_metrics " , " merge_requests " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " merge_request_metrics " , " users " , column : " latest_closed_by_id " , name : " fk_ae440388cc " , on_delete : :nullify
add_foreign_key " merge_request_metrics " , " users " , column : " merged_by_id " , name : " fk_7f28d925f3 " , on_delete : :nullify
2017-09-10 17:25:29 +05:30
add_foreign_key " merge_requests " , " ci_pipelines " , column : " head_pipeline_id " , name : " fk_fd82eae0b9 " , on_delete : :nullify
2018-03-17 18:26:18 +05:30
add_foreign_key " merge_requests " , " merge_request_diffs " , column : " latest_merge_request_diff_id " , name : " fk_06067f5644 " , on_delete : :nullify
add_foreign_key " merge_requests " , " milestones " , name : " fk_6a5165a692 " , on_delete : :nullify
add_foreign_key " merge_requests " , " projects " , column : " source_project_id " , name : " fk_3308fe130c " , on_delete : :nullify
2017-09-10 17:25:29 +05:30
add_foreign_key " merge_requests " , " projects " , column : " target_project_id " , name : " fk_a6963e8447 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " merge_requests " , " users " , column : " assignee_id " , name : " fk_6149611a04 " , on_delete : :nullify
add_foreign_key " merge_requests " , " users " , column : " author_id " , name : " fk_e719a85f8a " , on_delete : :nullify
add_foreign_key " merge_requests " , " users " , column : " merge_user_id " , name : " fk_ad525e1f87 " , on_delete : :nullify
add_foreign_key " merge_requests " , " users " , column : " updated_by_id " , name : " fk_641731faff " , on_delete : :nullify
2016-09-29 09:46:39 +05:30
add_foreign_key " merge_requests_closing_issues " , " issues " , on_delete : :cascade
add_foreign_key " merge_requests_closing_issues " , " merge_requests " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " merge_trains " , " ci_pipelines " , column : " pipeline_id " , on_delete : :nullify
add_foreign_key " merge_trains " , " merge_requests " , on_delete : :cascade
add_foreign_key " merge_trains " , " projects " , column : " target_project_id " , on_delete : :cascade
add_foreign_key " merge_trains " , " users " , on_delete : :cascade
add_foreign_key " milestone_releases " , " milestones " , on_delete : :cascade
add_foreign_key " milestone_releases " , " releases " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " milestones " , " namespaces " , column : " group_id " , name : " fk_95650a40d4 " , on_delete : :cascade
add_foreign_key " milestones " , " projects " , name : " fk_9bd0a0c791 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " namespace_aggregation_schedules " , " namespaces " , on_delete : :cascade
add_foreign_key " namespace_root_storage_statistics " , " namespaces " , on_delete : :cascade
add_foreign_key " namespace_statistics " , " namespaces " , on_delete : :cascade
add_foreign_key " namespaces " , " namespaces " , column : " custom_project_templates_group_id " , name : " fk_e7a0b20a6b " , on_delete : :nullify
add_foreign_key " namespaces " , " plans " , name : " fk_fdd12e5b80 " , on_delete : :nullify
add_foreign_key " namespaces " , " projects " , column : " file_template_project_id " , name : " fk_319256d87a " , on_delete : :nullify
2018-11-08 19:23:39 +05:30
add_foreign_key " note_diff_files " , " notes " , column : " diff_note_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " notes " , " projects " , name : " fk_99e097b079 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " notes " , " reviews " , name : " fk_2e82291620 " , on_delete : :nullify
2018-11-18 11:00:15 +05:30
add_foreign_key " notification_settings " , " users " , name : " fk_0c95e91db7 " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " oauth_openid_requests " , " oauth_access_grants " , column : " access_grant_id " , name : " fk_oauth_openid_requests_oauth_access_grants_access_grant_id "
2019-12-16 22:33:55 +05:30
add_foreign_key " operations_feature_flag_scopes " , " operations_feature_flags " , column : " feature_flag_id " , on_delete : :cascade
add_foreign_key " operations_feature_flags " , " projects " , on_delete : :cascade
add_foreign_key " operations_feature_flags_clients " , " projects " , on_delete : :cascade
add_foreign_key " packages_maven_metadata " , " packages_packages " , column : " package_id " , name : " fk_be88aed360 " , on_delete : :cascade
add_foreign_key " packages_package_files " , " packages_packages " , column : " package_id " , name : " fk_86f0f182f8 " , on_delete : :cascade
add_foreign_key " packages_package_metadata " , " packages_packages " , column : " package_id " , on_delete : :cascade
add_foreign_key " packages_package_tags " , " packages_packages " , column : " package_id " , on_delete : :cascade
add_foreign_key " packages_packages " , " projects " , on_delete : :cascade
add_foreign_key " pages_domain_acme_orders " , " pages_domains " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " pages_domains " , " projects " , name : " fk_ea2f6dfc6f " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " path_locks " , " projects " , name : " fk_5265c98f24 " , on_delete : :cascade
add_foreign_key " path_locks " , " users "
2016-06-22 15:30:34 +05:30
add_foreign_key " personal_access_tokens " , " users "
2019-02-15 15:39:39 +05:30
add_foreign_key " pool_repositories " , " projects " , column : " source_project_id " , on_delete : :nullify
add_foreign_key " pool_repositories " , " shards " , on_delete : :restrict
2019-12-16 22:33:55 +05:30
add_foreign_key " project_alerting_settings " , " projects " , on_delete : :cascade
add_foreign_key " project_aliases " , " projects " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " project_authorizations " , " projects " , on_delete : :cascade
add_foreign_key " project_authorizations " , " users " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " project_auto_devops " , " projects " , on_delete : :cascade
2018-10-15 14:42:47 +05:30
add_foreign_key " project_ci_cd_settings " , " projects " , name : " fk_24c15d2f2e " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " project_custom_attributes " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " project_daily_statistics " , " projects " , on_delete : :cascade
2018-05-09 12:01:36 +05:30
add_foreign_key " project_deploy_tokens " , " deploy_tokens " , on_delete : :cascade
add_foreign_key " project_deploy_tokens " , " projects " , on_delete : :cascade
2019-02-15 15:39:39 +05:30
add_foreign_key " project_error_tracking_settings " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " project_feature_usages " , " projects " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " project_features " , " projects " , name : " fk_18513d9b92 " , on_delete : :cascade
add_foreign_key " project_group_links " , " projects " , name : " fk_daa8cee94c " , on_delete : :cascade
add_foreign_key " project_import_data " , " projects " , name : " fk_ffb9ee3a10 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " project_incident_management_settings " , " projects " , on_delete : :cascade
add_foreign_key " project_metrics_settings " , " projects " , on_delete : :cascade
add_foreign_key " project_mirror_data " , " projects " , name : " fk_d1aad367d7 " , on_delete : :cascade
2019-02-15 15:39:39 +05:30
add_foreign_key " project_repositories " , " projects " , on_delete : :cascade
add_foreign_key " project_repositories " , " shards " , on_delete : :restrict
2019-12-16 22:33:55 +05:30
add_foreign_key " project_repository_states " , " projects " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " project_statistics " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " project_tracing_settings " , " projects " , on_delete : :cascade
2019-02-15 15:39:39 +05:30
add_foreign_key " projects " , " pool_repositories " , name : " fk_6e5c14658a " , on_delete : :nullify
2019-12-16 22:33:55 +05:30
add_foreign_key " prometheus_alert_events " , " projects " , on_delete : :cascade
add_foreign_key " prometheus_alert_events " , " prometheus_alerts " , on_delete : :cascade
add_foreign_key " prometheus_alerts " , " environments " , on_delete : :cascade
add_foreign_key " prometheus_alerts " , " projects " , on_delete : :cascade
add_foreign_key " prometheus_alerts " , " prometheus_metrics " , on_delete : :cascade
2018-11-20 20:47:30 +05:30
add_foreign_key " prometheus_metrics " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " protected_branch_merge_access_levels " , " namespaces " , column : " group_id " , name : " fk_98f3d044fe " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " protected_branch_merge_access_levels " , " protected_branches " , name : " fk_8a3072ccb3 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " protected_branch_merge_access_levels " , " users "
add_foreign_key " protected_branch_push_access_levels " , " namespaces " , column : " group_id " , name : " fk_7111b68cdb " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " protected_branch_push_access_levels " , " protected_branches " , name : " fk_9ffc86a3d9 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " protected_branch_push_access_levels " , " users "
add_foreign_key " protected_branch_unprotect_access_levels " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " protected_branch_unprotect_access_levels " , " protected_branches " , on_delete : :cascade
add_foreign_key " protected_branch_unprotect_access_levels " , " users " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " protected_branches " , " projects " , name : " fk_7a9c6d93e7 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " protected_environment_deploy_access_levels " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " protected_environment_deploy_access_levels " , " protected_environments " , on_delete : :cascade
add_foreign_key " protected_environment_deploy_access_levels " , " users " , on_delete : :cascade
add_foreign_key " protected_environments " , " projects " , on_delete : :cascade
add_foreign_key " protected_tag_create_access_levels " , " namespaces " , column : " group_id " , name : " fk_b4eb82fe3c " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " protected_tag_create_access_levels " , " protected_tags " , name : " fk_f7dfda8c51 " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " protected_tag_create_access_levels " , " users "
2017-09-10 17:25:29 +05:30
add_foreign_key " protected_tags " , " projects " , name : " fk_8e4af87648 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " push_event_payloads " , " events " , name : " fk_36c74129da " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " push_rules " , " projects " , name : " fk_83b29894de " , on_delete : :cascade
2019-02-15 15:39:39 +05:30
add_foreign_key " release_links " , " releases " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " releases " , " projects " , name : " fk_47fe2a0596 " , on_delete : :cascade
2019-02-15 15:39:39 +05:30
add_foreign_key " releases " , " users " , column : " author_id " , name : " fk_8e4456f90f " , on_delete : :nullify
2019-12-16 22:33:55 +05:30
add_foreign_key " remote_mirrors " , " projects " , name : " fk_43a9aa4ca8 " , on_delete : :cascade
2018-11-18 11:00:15 +05:30
add_foreign_key " repository_languages " , " projects " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " resource_label_events " , " epics " , on_delete : :cascade
2018-11-18 11:00:15 +05:30
add_foreign_key " resource_label_events " , " issues " , on_delete : :cascade
add_foreign_key " resource_label_events " , " labels " , on_delete : :nullify
add_foreign_key " resource_label_events " , " merge_requests " , on_delete : :cascade
add_foreign_key " resource_label_events " , " users " , on_delete : :nullify
2019-12-16 22:33:55 +05:30
add_foreign_key " reviews " , " merge_requests " , on_delete : :cascade
add_foreign_key " reviews " , " projects " , on_delete : :cascade
add_foreign_key " reviews " , " users " , column : " author_id " , on_delete : :nullify
add_foreign_key " saml_providers " , " namespaces " , column : " group_id " , on_delete : :cascade
add_foreign_key " scim_oauth_access_tokens " , " namespaces " , column : " group_id " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " services " , " projects " , name : " fk_71cce407f9 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " slack_integrations " , " services " , on_delete : :cascade
add_foreign_key " smartcard_identities " , " users " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " snippets " , " projects " , name : " fk_be41fd4bb7 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " software_license_policies " , " projects " , on_delete : :cascade
add_foreign_key " software_license_policies " , " software_licenses " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " subscriptions " , " projects " , on_delete : :cascade
2019-02-15 15:39:39 +05:30
add_foreign_key " suggestions " , " notes " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " system_note_metadata " , " notes " , name : " fk_d83a918cb1 " , on_delete : :cascade
2018-10-15 14:42:47 +05:30
add_foreign_key " term_agreements " , " application_setting_terms " , column : " term_id "
add_foreign_key " term_agreements " , " users " , on_delete : :cascade
2017-08-17 22:00:37 +05:30
add_foreign_key " timelogs " , " issues " , name : " fk_timelogs_issues_issue_id " , on_delete : :cascade
add_foreign_key " timelogs " , " merge_requests " , name : " fk_timelogs_merge_requests_merge_request_id " , on_delete : :cascade
2018-11-18 11:00:15 +05:30
add_foreign_key " todos " , " namespaces " , column : " group_id " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " todos " , " notes " , name : " fk_91d1f47b13 " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " todos " , " projects " , name : " fk_45054f9c45 " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " todos " , " users " , column : " author_id " , name : " fk_ccf0373936 " , on_delete : :cascade
add_foreign_key " todos " , " users " , name : " fk_d94154aa95 " , on_delete : :cascade
2016-11-03 12:29:30 +05:30
add_foreign_key " trending_projects " , " projects " , on_delete : :cascade
2016-06-16 23:09:34 +05:30
add_foreign_key " u2f_registrations " , " users "
2018-03-17 18:26:18 +05:30
add_foreign_key " user_callouts " , " users " , on_delete : :cascade
add_foreign_key " user_custom_attributes " , " users " , on_delete : :cascade
2018-03-27 19:54:05 +05:30
add_foreign_key " user_interacted_projects " , " projects " , name : " fk_722ceba4f7 " , on_delete : :cascade
add_foreign_key " user_interacted_projects " , " users " , name : " fk_0894651f08 " , on_delete : :cascade
2018-12-13 13:39:08 +05:30
add_foreign_key " user_preferences " , " users " , on_delete : :cascade
2018-11-18 11:00:15 +05:30
add_foreign_key " user_statuses " , " users " , on_delete : :cascade
2018-03-17 18:26:18 +05:30
add_foreign_key " user_synced_attributes_metadata " , " users " , on_delete : :cascade
2018-10-15 14:42:47 +05:30
add_foreign_key " users " , " application_setting_terms " , column : " accepted_term_id " , name : " fk_789cd90b35 " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " users " , " namespaces " , column : " managing_group_id " , name : " fk_a4b8fefe3e " , on_delete : :nullify
add_foreign_key " users_ops_dashboard_projects " , " projects " , on_delete : :cascade
add_foreign_key " users_ops_dashboard_projects " , " users " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " users_star_projects " , " projects " , name : " fk_22cd27ddfc " , on_delete : :cascade
2019-12-16 22:33:55 +05:30
add_foreign_key " vulnerability_feedback " , " ci_pipelines " , column : " pipeline_id " , on_delete : :nullify
add_foreign_key " vulnerability_feedback " , " issues " , on_delete : :nullify
add_foreign_key " vulnerability_feedback " , " merge_requests " , name : " fk_563ff1912e " , on_delete : :nullify
add_foreign_key " vulnerability_feedback " , " projects " , on_delete : :cascade
add_foreign_key " vulnerability_feedback " , " users " , column : " author_id " , on_delete : :cascade
add_foreign_key " vulnerability_feedback " , " users " , column : " comment_author_id " , name : " fk_94f7c8a81e " , on_delete : :nullify
add_foreign_key " vulnerability_identifiers " , " projects " , on_delete : :cascade
add_foreign_key " vulnerability_occurrence_identifiers " , " vulnerability_identifiers " , column : " identifier_id " , on_delete : :cascade
add_foreign_key " vulnerability_occurrence_identifiers " , " vulnerability_occurrences " , column : " occurrence_id " , on_delete : :cascade
add_foreign_key " vulnerability_occurrence_pipelines " , " ci_pipelines " , column : " pipeline_id " , on_delete : :cascade
add_foreign_key " vulnerability_occurrence_pipelines " , " vulnerability_occurrences " , column : " occurrence_id " , on_delete : :cascade
add_foreign_key " vulnerability_occurrences " , " projects " , on_delete : :cascade
add_foreign_key " vulnerability_occurrences " , " vulnerability_identifiers " , column : " primary_identifier_id " , on_delete : :cascade
add_foreign_key " vulnerability_occurrences " , " vulnerability_scanners " , column : " scanner_id " , on_delete : :cascade
add_foreign_key " vulnerability_scanners " , " projects " , on_delete : :cascade
2017-09-10 17:25:29 +05:30
add_foreign_key " web_hook_logs " , " web_hooks " , on_delete : :cascade
add_foreign_key " web_hooks " , " projects " , name : " fk_0c8ca6d9d1 " , on_delete : :cascade
2016-09-29 09:46:39 +05:30
end