uffizzi_core 0.1.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/LICENSE +201 -0
- data/README.md +46 -0
- data/Rakefile +31 -0
- data/app/assets/config/uffizzi_core_manifest.js +1 -0
- data/app/assets/stylesheets/uffizzi_core/application.css +15 -0
- data/app/clients/uffizzi_core/amazon_registry_client.rb +18 -0
- data/app/clients/uffizzi_core/azure_registry_client/request_result.rb +5 -0
- data/app/clients/uffizzi_core/azure_registry_client.rb +42 -0
- data/app/clients/uffizzi_core/controller_client/request_result.rb +5 -0
- data/app/clients/uffizzi_core/controller_client.rb +106 -0
- data/app/clients/uffizzi_core/docker_hub_client/request_result.rb +7 -0
- data/app/clients/uffizzi_core/docker_hub_client.rb +139 -0
- data/app/clients/uffizzi_core/github/app_client.rb +19 -0
- data/app/clients/uffizzi_core/github/installation_client.rb +11 -0
- data/app/clients/uffizzi_core/github/user_client.rb +51 -0
- data/app/clients/uffizzi_core/google_registry_client/request_result.rb +5 -0
- data/app/clients/uffizzi_core/google_registry_client.rb +42 -0
- data/app/contexts/uffizzi_core/base_context.rb +12 -0
- data/app/contexts/uffizzi_core/project_context.rb +13 -0
- data/app/contexts/uffizzi_core/webhooks_context.rb +9 -0
- data/app/controllers/concerns/uffizzi_core/auth_management.rb +23 -0
- data/app/controllers/concerns/uffizzi_core/authorization_concern.rb +38 -0
- data/app/controllers/concerns/uffizzi_core/dependency_injection_concern.rb +19 -0
- data/app/controllers/uffizzi_core/api/cli/v1/account/application_controller.rb +7 -0
- data/app/controllers/uffizzi_core/api/cli/v1/account/credentials_controller.rb +55 -0
- data/app/controllers/uffizzi_core/api/cli/v1/application_controller.rb +5 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/application_controller.rb +11 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/compose_files_controller.rb +93 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments/activity_items_controller.rb +36 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments/application_controller.rb +7 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments/containers/application_controller.rb +8 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments/containers/logs_controller.rb +27 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments/containers_controller.rb +24 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments/events_controller.rb +29 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/deployments_controller.rb +148 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects/secrets_controller.rb +69 -0
- data/app/controllers/uffizzi_core/api/cli/v1/projects_controller.rb +19 -0
- data/app/controllers/uffizzi_core/api/cli/v1/sessions_controller.rb +43 -0
- data/app/controllers/uffizzi_core/application_controller.rb +51 -0
- data/app/errors/uffizzi_core/compose_file/build_error.rb +4 -0
- data/app/errors/uffizzi_core/compose_file/credential_error.rb +4 -0
- data/app/errors/uffizzi_core/compose_file/not_found_error.rb +4 -0
- data/app/errors/uffizzi_core/compose_file/parse_error.rb +4 -0
- data/app/errors/uffizzi_core/compose_file/secrets_error.rb +4 -0
- data/app/errors/uffizzi_core/deployment_not_found_error.rb +10 -0
- data/app/forms/uffizzi_core/api/cli/v1/account/credential/create_form.rb +26 -0
- data/app/forms/uffizzi_core/api/cli/v1/compose_file/check_credentials_form.rb +21 -0
- data/app/forms/uffizzi_core/api/cli/v1/compose_file/cli_form.rb +39 -0
- data/app/forms/uffizzi_core/api/cli/v1/compose_file/create_form.rb +13 -0
- data/app/forms/uffizzi_core/api/cli/v1/compose_file/template_form.rb +44 -0
- data/app/forms/uffizzi_core/api/cli/v1/compose_file/update_form.rb +9 -0
- data/app/forms/uffizzi_core/api/cli/v1/config_file/create_form.rb +11 -0
- data/app/forms/uffizzi_core/api/cli/v1/deployment/create_form.rb +91 -0
- data/app/forms/uffizzi_core/api/cli/v1/project/delete_secret_form.rb +27 -0
- data/app/forms/uffizzi_core/api/cli/v1/project/update_form.rb +40 -0
- data/app/forms/uffizzi_core/api/cli/v1/session_create_form.rb +29 -0
- data/app/forms/uffizzi_core/api/cli/v1/template/create_form.rb +65 -0
- data/app/forms/uffizzi_core/application_form.rb +11 -0
- data/app/forms/uffizzi_core/application_form_without_active_record.rb +17 -0
- data/app/forms/uffizzi_core/mass_assignment_control_concern.rb +22 -0
- data/app/helpers/uffizzi_core/application_helper.rb +6 -0
- data/app/jobs/uffizzi_core/account/create_credential_job.rb +10 -0
- data/app/jobs/uffizzi_core/activity_item/docker/update_digest_job.rb +11 -0
- data/app/jobs/uffizzi_core/application_job.rb +7 -0
- data/app/jobs/uffizzi_core/config_file/apply_job.rb +31 -0
- data/app/jobs/uffizzi_core/credential/docker_hub/create_webhook_job.rb +15 -0
- data/app/jobs/uffizzi_core/deployment/create_credential_job.rb +32 -0
- data/app/jobs/uffizzi_core/deployment/create_credentials_job.rb +17 -0
- data/app/jobs/uffizzi_core/deployment/create_job.rb +15 -0
- data/app/jobs/uffizzi_core/deployment/create_webhooks_job.rb +13 -0
- data/app/jobs/uffizzi_core/deployment/delete_credential_job.rb +13 -0
- data/app/jobs/uffizzi_core/deployment/delete_job.rb +11 -0
- data/app/jobs/uffizzi_core/deployment/deploy_containers_job.rb +27 -0
- data/app/jobs/uffizzi_core/deployment/manage_deploy_activity_item_job.rb +19 -0
- data/app/jobs/uffizzi_core/deployment/send_github_preview_message_job.rb +13 -0
- data/app/lib/uffizzi_core/rbac/user_access_service.rb +21 -0
- data/app/mailers/uffizzi_core/application_mailer.rb +8 -0
- data/app/models/concerns/uffizzi_core/hashid_concern.rb +25 -0
- data/app/models/concerns/uffizzi_core/state_machine_concern.rb +16 -0
- data/app/models/uffizzi_core/account.rb +101 -0
- data/app/models/uffizzi_core/activity_item/docker.rb +4 -0
- data/app/models/uffizzi_core/activity_item/github.rb +4 -0
- data/app/models/uffizzi_core/activity_item/memory_limit.rb +4 -0
- data/app/models/uffizzi_core/activity_item.rb +58 -0
- data/app/models/uffizzi_core/application_record.rb +7 -0
- data/app/models/uffizzi_core/build.rb +39 -0
- data/app/models/uffizzi_core/comment.rb +16 -0
- data/app/models/uffizzi_core/compose_file.rb +57 -0
- data/app/models/uffizzi_core/config_file.rb +24 -0
- data/app/models/uffizzi_core/container.rb +100 -0
- data/app/models/uffizzi_core/container_config_file.rb +8 -0
- data/app/models/uffizzi_core/continuous_preview.rb +4 -0
- data/app/models/uffizzi_core/coupon.rb +5 -0
- data/app/models/uffizzi_core/credential/amazon.rb +4 -0
- data/app/models/uffizzi_core/credential/azure.rb +4 -0
- data/app/models/uffizzi_core/credential/docker_hub.rb +4 -0
- data/app/models/uffizzi_core/credential/github.rb +4 -0
- data/app/models/uffizzi_core/credential/google.rb +4 -0
- data/app/models/uffizzi_core/credential.rb +64 -0
- data/app/models/uffizzi_core/database.rb +4 -0
- data/app/models/uffizzi_core/database_offering.rb +4 -0
- data/app/models/uffizzi_core/deployment.rb +77 -0
- data/app/models/uffizzi_core/event.rb +13 -0
- data/app/models/uffizzi_core/invitation.rb +27 -0
- data/app/models/uffizzi_core/membership.rb +16 -0
- data/app/models/uffizzi_core/payment.rb +11 -0
- data/app/models/uffizzi_core/price.rb +9 -0
- data/app/models/uffizzi_core/product.rb +11 -0
- data/app/models/uffizzi_core/project.rb +66 -0
- data/app/models/uffizzi_core/rating.rb +20 -0
- data/app/models/uffizzi_core/repo/amazon.rb +4 -0
- data/app/models/uffizzi_core/repo/azure.rb +4 -0
- data/app/models/uffizzi_core/repo/docker_hub.rb +4 -0
- data/app/models/uffizzi_core/repo/github.rb +4 -0
- data/app/models/uffizzi_core/repo/google.rb +4 -0
- data/app/models/uffizzi_core/repo.rb +39 -0
- data/app/models/uffizzi_core/role.rb +17 -0
- data/app/models/uffizzi_core/template.rb +19 -0
- data/app/models/uffizzi_core/user.rb +62 -0
- data/app/models/uffizzi_core/user_project.rb +14 -0
- data/app/policies/uffizzi_core/api/cli/v1/account/credentials_policy.rb +11 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects/compose_files_policy.rb +15 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects/deployments/activity_items_policy.rb +7 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects/deployments/containers_policy.rb +7 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects/deployments/events_policy.rb +7 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects/deployments_policy.rb +23 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects/secrets_policy.rb +15 -0
- data/app/policies/uffizzi_core/api/cli/v1/projects_policy.rb +7 -0
- data/app/policies/uffizzi_core/application_policy.rb +12 -0
- data/app/repositories/uffizzi_core/activity_item_repo.rb +9 -0
- data/app/repositories/uffizzi_core/basic_order_repo.rb +11 -0
- data/app/repositories/uffizzi_core/build_repo.rb +23 -0
- data/app/repositories/uffizzi_core/comment_repo.rb +11 -0
- data/app/repositories/uffizzi_core/compose_file_repo.rb +11 -0
- data/app/repositories/uffizzi_core/config_file_repo.rb +40 -0
- data/app/repositories/uffizzi_core/container_repo.rb +25 -0
- data/app/repositories/uffizzi_core/credential_repo.rb +36 -0
- data/app/repositories/uffizzi_core/deployment_repo.rb +23 -0
- data/app/repositories/uffizzi_core/event_repo.rb +9 -0
- data/app/repositories/uffizzi_core/membership_repo.rb +10 -0
- data/app/repositories/uffizzi_core/price_repo.rb +11 -0
- data/app/repositories/uffizzi_core/product_repo.rb +11 -0
- data/app/repositories/uffizzi_core/project_repo.rb +10 -0
- data/app/repositories/uffizzi_core/repo_repo.rb +10 -0
- data/app/repositories/uffizzi_core/template_repo.rb +87 -0
- data/app/repositories/uffizzi_core/usage_repo.rb +9 -0
- data/app/repositories/uffizzi_core/user_repo.rb +11 -0
- data/app/responders/uffizzi_core/json_responder.rb +13 -0
- data/app/serializers/uffizzi_core/api/cli/v1/account/credential_serializer.rb +9 -0
- data/app/serializers/uffizzi_core/api/cli/v1/project_serializer.rb +7 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/compose_file_serializer.rb +7 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployment_serializer/container_serializer.rb +23 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployment_serializer/user_serializer.rb +11 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployment_serializer.rb +74 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployments/activity_item_serializer.rb +24 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployments/container_serializer/container_config_file_serializer/config_file_serializer.rb +6 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployments/container_serializer/container_config_file_serializer.rb +7 -0
- data/app/serializers/uffizzi_core/api/cli/v1/projects/deployments/container_serializer.rb +30 -0
- data/app/serializers/uffizzi_core/api/cli/v1/user_serializer/account_serializer.rb +5 -0
- data/app/serializers/uffizzi_core/api/cli/v1/user_serializer.rb +7 -0
- data/app/serializers/uffizzi_core/base_serializer.rb +7 -0
- data/app/serializers/uffizzi_core/controller/create_credential/credential_serializer.rb +17 -0
- data/app/serializers/uffizzi_core/controller/create_deployment/deployment_serializer.rb +5 -0
- data/app/serializers/uffizzi_core/controller/deploy_containers/container_serializer.rb +53 -0
- data/app/serializers/uffizzi_core/controller/deploy_containers/credential_serializer.rb +5 -0
- data/app/services/uffizzi_core/account_service.rb +21 -0
- data/app/services/uffizzi_core/activity_item_service.rb +98 -0
- data/app/services/uffizzi_core/amazon/credential_service.rb +31 -0
- data/app/services/uffizzi_core/amazon_service.rb +45 -0
- data/app/services/uffizzi_core/azure/credential_service.rb +18 -0
- data/app/services/uffizzi_core/cli/compose_file_service.rb +203 -0
- data/app/services/uffizzi_core/compose_file/builders/config_files_builder_service.rb +31 -0
- data/app/services/uffizzi_core/compose_file/builders/container_builder_service.rb +225 -0
- data/app/services/uffizzi_core/compose_file/builders/docker_repo_builder_service.rb +25 -0
- data/app/services/uffizzi_core/compose_file/builders/github_repo_builder_service.rb +59 -0
- data/app/services/uffizzi_core/compose_file/builders/template_builder_service.rb +45 -0
- data/app/services/uffizzi_core/compose_file/builders/variables_builder_service.rb +58 -0
- data/app/services/uffizzi_core/compose_file/config_files_service.rb +52 -0
- data/app/services/uffizzi_core/compose_file/config_option_service.rb +37 -0
- data/app/services/uffizzi_core/compose_file/configs_options_service.rb +26 -0
- data/app/services/uffizzi_core/compose_file/container_service.rb +64 -0
- data/app/services/uffizzi_core/compose_file/continuous_preview_options_service.rb +57 -0
- data/app/services/uffizzi_core/compose_file/dependencies_service.rb +55 -0
- data/app/services/uffizzi_core/compose_file/errors_service.rb +46 -0
- data/app/services/uffizzi_core/compose_file/github_dependencies_service.rb +38 -0
- data/app/services/uffizzi_core/compose_file/ingress_options_service.rb +49 -0
- data/app/services/uffizzi_core/compose_file/secrets_options_service.rb +28 -0
- data/app/services/uffizzi_core/compose_file/services_options/build_service.rb +93 -0
- data/app/services/uffizzi_core/compose_file/services_options/command_service.rb +18 -0
- data/app/services/uffizzi_core/compose_file/services_options/configs_service.rb +51 -0
- data/app/services/uffizzi_core/compose_file/services_options/deploy_service.rb +44 -0
- data/app/services/uffizzi_core/compose_file/services_options/entrypoint_service.rb +18 -0
- data/app/services/uffizzi_core/compose_file/services_options/env_file_service.rb +34 -0
- data/app/services/uffizzi_core/compose_file/services_options/environment_service.rb +20 -0
- data/app/services/uffizzi_core/compose_file/services_options/image_service.rb +89 -0
- data/app/services/uffizzi_core/compose_file/services_options/secrets_service.rb +35 -0
- data/app/services/uffizzi_core/compose_file/services_options_service.rb +55 -0
- data/app/services/uffizzi_core/compose_file/template_service.rb +55 -0
- data/app/services/uffizzi_core/compose_file/update_service.rb +29 -0
- data/app/services/uffizzi_core/compose_file/variables_service.rb +25 -0
- data/app/services/uffizzi_core/compose_file_service.rb +33 -0
- data/app/services/uffizzi_core/container_service.rb +57 -0
- data/app/services/uffizzi_core/controller_service.rb +80 -0
- data/app/services/uffizzi_core/credential_service.rb +44 -0
- data/app/services/uffizzi_core/deployment_service.rb +274 -0
- data/app/services/uffizzi_core/docker_hub/credential_service.rb +15 -0
- data/app/services/uffizzi_core/docker_hub_service.rb +77 -0
- data/app/services/uffizzi_core/github/app_service.rb +51 -0
- data/app/services/uffizzi_core/github/credential_service.rb +124 -0
- data/app/services/uffizzi_core/github/message_service.rb +20 -0
- data/app/services/uffizzi_core/github_service.rb +28 -0
- data/app/services/uffizzi_core/google/credential_service.rb +18 -0
- data/app/services/uffizzi_core/logs_service.rb +33 -0
- data/app/services/uffizzi_core/manage_activity_items_service.rb +166 -0
- data/app/services/uffizzi_core/project_service.rb +38 -0
- data/app/services/uffizzi_core/repo_service.rb +178 -0
- data/app/services/uffizzi_core/response_service.rb +13 -0
- data/app/services/uffizzi_core/template_service.rb +21 -0
- data/app/services/uffizzi_core/token_service.rb +19 -0
- data/app/services/uffizzi_core/user_access_service.rb +14 -0
- data/app/utils/uffizzi_core/converters.rb +33 -0
- data/app/validators/uffizzi_core/email_validator.rb +9 -0
- data/app/validators/uffizzi_core/environment_variable_list_validator.rb +15 -0
- data/app/validators/uffizzi_core/image_command_args_validator.rb +21 -0
- data/config/initializers/rswag_api.rb +15 -0
- data/config/initializers/rswag_ui.rb +15 -0
- data/config/initializers/swagger_yard.rb +17 -0
- data/config/locales/en.activerecord.yml +18 -0
- data/config/locales/en.yml +61 -0
- data/config/routes.rb +55 -0
- data/db/migrate/20220218121438_create_uffizzi_core_tables.rb +375 -0
- data/db/migrate/20220325113342_add_name_to_uffizzi_containers.rb +7 -0
- data/db/seeds.rb +16 -0
- data/lib/tasks/uffizzi_core_tasks.rake +14 -0
- data/lib/uffizzi_core/engine.rb +15 -0
- data/lib/uffizzi_core/version.rb +5 -0
- data/lib/uffizzi_core.rb +60 -0
- data/swagger/v1/swagger.json +1278 -0
- metadata +935 -0
@@ -0,0 +1,62 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::User < ActiveRecord::Base
|
4
|
+
include AASM
|
5
|
+
include ActiveModel::Validations
|
6
|
+
include UffizziCore::StateMachineConcern
|
7
|
+
include UffizziCore::HashidConcern
|
8
|
+
include UffizziCore::UserRepo
|
9
|
+
extend Enumerize
|
10
|
+
|
11
|
+
self.table_name = UffizziCore.table_names[:users]
|
12
|
+
|
13
|
+
rolify
|
14
|
+
|
15
|
+
has_secure_password
|
16
|
+
|
17
|
+
validates :email, presence: true, 'uffizzi_core/email': true, uniqueness: { case_sensitive: false }
|
18
|
+
validates :password, allow_nil: true, length: { minimum: 8 }, on: :update
|
19
|
+
|
20
|
+
has_many :memberships, dependent: :destroy
|
21
|
+
has_many :accounts, through: :memberships
|
22
|
+
has_many :user_projects
|
23
|
+
has_many :projects, through: :user_projects
|
24
|
+
|
25
|
+
has_one_attached :avatar
|
26
|
+
|
27
|
+
enumerize :creation_source, in: [:system, :online_registration, :google, :sso], predicates: true
|
28
|
+
|
29
|
+
def organizational_account
|
30
|
+
accounts.find_by(kind: UffizziCore::Account.kind.organizational)
|
31
|
+
end
|
32
|
+
|
33
|
+
def active_projects
|
34
|
+
projects.active
|
35
|
+
end
|
36
|
+
|
37
|
+
def deployments
|
38
|
+
UffizziCore::Deployment.where(project_id: active_projects)
|
39
|
+
end
|
40
|
+
|
41
|
+
def full_name
|
42
|
+
"#{first_name} #{last_name}"
|
43
|
+
end
|
44
|
+
|
45
|
+
aasm(:state) do
|
46
|
+
state :initial, initial: true
|
47
|
+
state :active
|
48
|
+
state :disabled
|
49
|
+
|
50
|
+
event :activate do
|
51
|
+
transitions from: [:initial, :disabled], to: :active
|
52
|
+
end
|
53
|
+
|
54
|
+
event :disable do
|
55
|
+
transitions from: [:initial, :active], to: :disabled
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
def admin_access_to_project?(project)
|
60
|
+
projects.by_ids(project).by_accounts(memberships.by_role_admin.select(:account_id)).exists?
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::UserProject < UffizziCore::ApplicationRecord
|
4
|
+
extend Enumerize
|
5
|
+
|
6
|
+
self.table_name = UffizziCore.table_names[:user_projects]
|
7
|
+
|
8
|
+
enumerize :role, in: [:admin, :developer, :viewer], predicates: true
|
9
|
+
validates :role, presence: true
|
10
|
+
|
11
|
+
belongs_to :user
|
12
|
+
belongs_to :project
|
13
|
+
belongs_to :invited_by, class_name: UffizziCore::User.name, foreign_key: :invited_by_id, optional: true
|
14
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::Api::Cli::V1::Account::CredentialsPolicy < UffizziCore::ApplicationPolicy
|
4
|
+
def create?
|
5
|
+
context.user_access_module.admin_access_to_account?(context.user, context.account)
|
6
|
+
end
|
7
|
+
|
8
|
+
def destroy?
|
9
|
+
context.user_access_module.admin_access_to_account?(context.user, context.account)
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::Api::Cli::V1::Projects::ComposeFilesPolicy < UffizziCore::ApplicationPolicy
|
4
|
+
def show?
|
5
|
+
context.user_access_module.any_access_to_project?(context.user, context.project)
|
6
|
+
end
|
7
|
+
|
8
|
+
def create?
|
9
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
10
|
+
end
|
11
|
+
|
12
|
+
def destroy?
|
13
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::Api::Cli::V1::Projects::DeploymentsPolicy < UffizziCore::ApplicationPolicy
|
4
|
+
def index?
|
5
|
+
context.user_access_module.any_access_to_project?(context.user, context.project)
|
6
|
+
end
|
7
|
+
|
8
|
+
def show?
|
9
|
+
context.user_access_module.any_access_to_project?(context.user, context.project)
|
10
|
+
end
|
11
|
+
|
12
|
+
def create?
|
13
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
14
|
+
end
|
15
|
+
|
16
|
+
def destroy?
|
17
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
18
|
+
end
|
19
|
+
|
20
|
+
def deploy_containers?
|
21
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::Api::Cli::V1::Projects::SecretsPolicy < UffizziCore::ApplicationPolicy
|
4
|
+
def index?
|
5
|
+
context.user_access_module.any_access_to_project?(context.user, context.project)
|
6
|
+
end
|
7
|
+
|
8
|
+
def bulk_create?
|
9
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
10
|
+
end
|
11
|
+
|
12
|
+
def destroy?
|
13
|
+
context.user_access_module.admin_or_developer_access_to_project?(context.user, context.project)
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::ApplicationPolicy
|
4
|
+
attr_reader :context, :record
|
5
|
+
|
6
|
+
def initialize(context, record)
|
7
|
+
raise Pundit::NotAuthorizedError, 'must be logged in' if !context.instance_of?(UffizziCore::WebhooksContext) && context.user.blank?
|
8
|
+
|
9
|
+
@record = record
|
10
|
+
@context = context
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::BuildRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
scope :successful, -> {
|
8
|
+
where(status: UffizziCore::Build::SUCCESS)
|
9
|
+
}
|
10
|
+
|
11
|
+
scope :building, -> {
|
12
|
+
where(status: UffizziCore::Build::BUILDING)
|
13
|
+
}
|
14
|
+
|
15
|
+
scope :queued, -> {
|
16
|
+
where(status: [nil])
|
17
|
+
}
|
18
|
+
|
19
|
+
scope :deployed, -> {
|
20
|
+
where(deployed: true)
|
21
|
+
}
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::ConfigFileRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
scope :by_deployment, ->(deployment) {
|
8
|
+
select(:id)
|
9
|
+
.joins(:container_config_files)
|
10
|
+
.where(container_config_files: { container: deployment.containers })
|
11
|
+
.distinct
|
12
|
+
}
|
13
|
+
|
14
|
+
scope :by_source, ->(source) {
|
15
|
+
where(source: source)
|
16
|
+
}
|
17
|
+
|
18
|
+
scope :only_used_config_files, -> {
|
19
|
+
select(:id)
|
20
|
+
.where("(id = ANY(ARRAY(select distinct(
|
21
|
+
jsonb_array_elements(
|
22
|
+
(
|
23
|
+
jsonb_array_elements(
|
24
|
+
jsonb_extract_path_text(
|
25
|
+
payload::jsonb, 'containers_attributes'
|
26
|
+
)::jsonb
|
27
|
+
) ->> 'container_config_files_attributes'
|
28
|
+
)::jsonb
|
29
|
+
) ->> 'config_file_id'
|
30
|
+
) as ids from templates)::int[]))")
|
31
|
+
.or(
|
32
|
+
UffizziCore::ConfigFile.where(
|
33
|
+
id: UffizziCore::ContainerConfigFile.where(
|
34
|
+
container_id: UffizziCore::Container.active.select(:id),
|
35
|
+
).select(:config_file_id),
|
36
|
+
),
|
37
|
+
)
|
38
|
+
}
|
39
|
+
end
|
40
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::ContainerRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
include UffizziCore::BasicOrderRepo
|
8
|
+
|
9
|
+
scope :with_github_repo, -> { includes(:repo).where(repo: { type: UffizziCore::Repo::Github.name }) }
|
10
|
+
scope :with_amazon_repo, -> { includes(:repo).where(repo: { type: UffizziCore::Repo::Amazon.name }) }
|
11
|
+
scope :with_docker_hub_repo, -> { includes(:repo).where(repo: { type: UffizziCore::Repo::DockerHub.name }) }
|
12
|
+
|
13
|
+
scope :with_public_access, -> {
|
14
|
+
where(public: true)
|
15
|
+
}
|
16
|
+
|
17
|
+
scope :with_enabled_continuously_deploy, -> {
|
18
|
+
where(continuously_deploy: UffizziCore::Container::STATE_ENABLED)
|
19
|
+
}
|
20
|
+
|
21
|
+
scope :by_repo_type, ->(type) {
|
22
|
+
includes(:repo).where(repo: { type: type })
|
23
|
+
}
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::CredentialRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
scope :docker_hub, -> {
|
8
|
+
where(type: UffizziCore::Credential::DockerHub.name)
|
9
|
+
}
|
10
|
+
|
11
|
+
scope :github, -> {
|
12
|
+
where(type: UffizziCore::Credential::Github.name)
|
13
|
+
}
|
14
|
+
|
15
|
+
scope :azure, -> {
|
16
|
+
where(type: UffizziCore::Credential::Azure.name)
|
17
|
+
}
|
18
|
+
|
19
|
+
scope :google, -> {
|
20
|
+
where(type: UffizziCore::Credential::Google.name)
|
21
|
+
}
|
22
|
+
|
23
|
+
scope :deployable, -> {
|
24
|
+
where(type: [
|
25
|
+
UffizziCore::Credential::DockerHub.name,
|
26
|
+
UffizziCore::Credential::Azure.name,
|
27
|
+
UffizziCore::Credential::Google.name,
|
28
|
+
UffizziCore::Credential::Amazon.name,
|
29
|
+
])
|
30
|
+
}
|
31
|
+
|
32
|
+
scope :amazon, -> {
|
33
|
+
where(type: UffizziCore::Credential::Amazon.name)
|
34
|
+
}
|
35
|
+
end
|
36
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::DeploymentRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
scope :with_name, ->(name) {
|
8
|
+
where(name: name)
|
9
|
+
}
|
10
|
+
scope :by_config_file, ->(config_file) {
|
11
|
+
container_config_files = UffizziCore::ContainerConfigFile.where(config_file: config_file)
|
12
|
+
containers = UffizziCore::Container.where(id: container_config_files.select(:container_id))
|
13
|
+
where(id: containers.select(:deployment_id))
|
14
|
+
}
|
15
|
+
scope :with_amazon_repos, -> { includes(containers: [:repo]).where(containers: { repos: { type: UffizziCore::Repo::Amazon.name } }) }
|
16
|
+
scope :by_templates, ->(templates) {
|
17
|
+
where(template: templates).where.not(templates: nil)
|
18
|
+
}
|
19
|
+
scope :with_containers, ->(source, image, tag) {
|
20
|
+
includes(containers: :repo).where(containers: { image: image, tag: tag, repos: { type: source } })
|
21
|
+
}
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::RepoRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
scope :docker_hub, -> { where(type: UffizziCore::Repo::DockerHub.name) }
|
8
|
+
scope :github, -> { where(type: UffizziCore::Repo::Github.name) }
|
9
|
+
end
|
10
|
+
end
|
@@ -0,0 +1,87 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UffizziCore::TemplateRepo
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
scope :by_docker_containers_with_deploy_preview_when_image_tag_is_created, ->(source, image, tag) {
|
8
|
+
general_query = {
|
9
|
+
containers_attributes: [
|
10
|
+
{
|
11
|
+
image: image,
|
12
|
+
repo_attributes: {
|
13
|
+
type: source,
|
14
|
+
deploy_preview_when_image_tag_is_created: true,
|
15
|
+
},
|
16
|
+
},
|
17
|
+
],
|
18
|
+
}
|
19
|
+
|
20
|
+
excluding_query = {
|
21
|
+
containers_attributes: [
|
22
|
+
{
|
23
|
+
image: image,
|
24
|
+
tag: tag,
|
25
|
+
repo_attributes: {
|
26
|
+
type: source,
|
27
|
+
deploy_preview_when_image_tag_is_created: true,
|
28
|
+
},
|
29
|
+
},
|
30
|
+
],
|
31
|
+
}
|
32
|
+
|
33
|
+
where('payload @> ?', general_query.to_json).where.not('payload @> ?', excluding_query.to_json)
|
34
|
+
}
|
35
|
+
|
36
|
+
scope :by_docker_containers_with_delete_preview_when_image_tag_is_updated, ->(source, image, tag) {
|
37
|
+
general_query = {
|
38
|
+
containers_attributes: [
|
39
|
+
{
|
40
|
+
image: image,
|
41
|
+
tag: tag,
|
42
|
+
repo_attributes: {
|
43
|
+
type: source,
|
44
|
+
delete_preview_when_image_tag_is_updated: true,
|
45
|
+
},
|
46
|
+
},
|
47
|
+
],
|
48
|
+
}
|
49
|
+
|
50
|
+
where('payload @> ?', general_query.to_json)
|
51
|
+
}
|
52
|
+
|
53
|
+
scope :by_github_containers_with_deploy_preview_when_pull_request_is_opened, ->(repository_id, branch) {
|
54
|
+
query = {
|
55
|
+
containers_attributes: [
|
56
|
+
{
|
57
|
+
repo_attributes: {
|
58
|
+
type: Repo::Github.name,
|
59
|
+
repository_id: repository_id,
|
60
|
+
branch: branch,
|
61
|
+
deploy_preview_when_pull_request_is_opened: true,
|
62
|
+
},
|
63
|
+
},
|
64
|
+
],
|
65
|
+
}
|
66
|
+
|
67
|
+
where('payload @> ?', query.to_json)
|
68
|
+
}
|
69
|
+
|
70
|
+
scope :by_github_containers_with_delete_preview_when_pull_request_is_closed, ->(repository_id, branch) {
|
71
|
+
query = {
|
72
|
+
containers_attributes: [
|
73
|
+
{
|
74
|
+
repo_attributes: {
|
75
|
+
type: Repo::Github.name,
|
76
|
+
repository_id: repository_id,
|
77
|
+
branch: branch,
|
78
|
+
delete_preview_when_pull_request_is_closed: true,
|
79
|
+
},
|
80
|
+
},
|
81
|
+
],
|
82
|
+
}
|
83
|
+
|
84
|
+
where('payload @> ?', query.to_json)
|
85
|
+
}
|
86
|
+
end
|
87
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::JsonResponder < ActionController::Responder
|
4
|
+
def api_behavior(*args, &block)
|
5
|
+
if post?
|
6
|
+
display(resource, status: :created)
|
7
|
+
elsif put? || patch?
|
8
|
+
display(resource, status: :ok)
|
9
|
+
else
|
10
|
+
super
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
data/app/serializers/uffizzi_core/api/cli/v1/projects/deployment_serializer/container_serializer.rb
ADDED
@@ -0,0 +1,23 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class UffizziCore::Api::Cli::V1::Projects::DeploymentSerializer::ContainerSerializer < UffizziCore::BaseSerializer
|
4
|
+
type :deployment
|
5
|
+
|
6
|
+
attributes :id,
|
7
|
+
:kind,
|
8
|
+
:image,
|
9
|
+
:tag,
|
10
|
+
:variables,
|
11
|
+
:secret_variables,
|
12
|
+
:created_at,
|
13
|
+
:updated_at,
|
14
|
+
:memory_limit,
|
15
|
+
:memory_request,
|
16
|
+
:entrypoint,
|
17
|
+
:command,
|
18
|
+
:port,
|
19
|
+
:public,
|
20
|
+
:repo_id,
|
21
|
+
:continuously_deploy,
|
22
|
+
:receive_incoming_requests
|
23
|
+
end
|