Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Snyk] Fix for 1 vulnerabilities #72

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

SPAHI4
Copy link
Owner

@SPAHI4 SPAHI4 commented Oct 7, 2024

snyk-top-banner

Snyk has created this PR to fix 1 vulnerabilities in the npm dependencies of this project.

Snyk changed the following file(s):

  • server/package.json

Vulnerabilities that will be fixed with an upgrade:

Issue Score
medium severity Cross-site Scripting (XSS)
SNYK-JS-COOKIE-8163060
  601  

Important

  • Check the changes in this PR to ensure they won't cause issues with your project.
  • Max score is 1000. Note that the real score may have changed since the PR was raised.
  • This PR was automatically created by Snyk using the credentials of a real user.

Note: You are seeing this because you or someone else with access to this repository has authorized Snyk to open fix PRs.

For more information:
🧐 View latest project report
📜 Customise PR templates
🛠 Adjust project settings
📚 Read about Snyk's upgrade logic


Learn how to fix vulnerabilities with free interactive lessons:

🦉 Cross-site Scripting (XSS)

Copy link

github-actions bot commented Oct 7, 2024

Terraform Format and Style 🖌success

Terraform Initialization ⚙️success

Terraform Validation 🤖success

Validation Output

Success! The configuration is valid.


Terraform Plan 📖success

Show Plan

terraform
data.template_file.db_init: Reading...
data.template_file.db_init: Read complete after 0s [id=9cfd5507d4ab0bcbba8622726474c10224cf2e0e5cb380fe5a8a7ce27df754e7]
data.cloudflare_ip_ranges.cloudflare: Reading...
data.cloudflare_zone.default: Reading...
data.cloudflare_ip_ranges.cloudflare: Read complete after 0s [id=2749251940]
data.cloudflare_zone.default: Read complete after 0s [id=912714793d16044d3fce7b01eedf537f]
cloudflare_worker_script.client: Refreshing state... [id=production__client]
cloudflare_page_rule.sitemap_redirect: Refreshing state... [id=102cbfc89f7fb42c3b66e25877d2464f]
aws_key_pair.deployer: Refreshing state... [id=prod-deployer-key]
aws_default_subnet.default: Refreshing state... [id=subnet-0016e0ee7efc40856]
data.aws_ecr_repository.ecr_repository: Reading...
aws_security_group.allow_ec2_ssh: Refreshing state... [id=sg-0079c501834fe8b3c]
aws_security_group.allow_ec2: Refreshing state... [id=sg-06addd6a0400c0f63]
aws_s3_bucket.image-storage: Refreshing state... [id=spahi4-photo-images-prod]
data.aws_ami.amazon_linux: Reading...
aws_security_group.allow_rds: Refreshing state... [id=sg-0a121ef3886ca5c25]
aws_s3_bucket.client: Refreshing state... [id=spahi4.me]
aws_iam_role.ec2_instance: Refreshing state... [id=production__ec2_instance]
aws_db_parameter_group.default: Refreshing state... [id=production-photo-app-db]
cloudflare_worker_route.client: Refreshing state... [id=2deaba8b7cfa4e1c87141f080d8d31ce]
aws_iam_role_policy.ecr_policy: Refreshing state... [id=production__ec2_instance:production_ecr_policy]
aws_iam_instance_profile.instance: Refreshing state... [id=production_instance_profile]
data.aws_ami.amazon_linux: Read complete after 1s [id=ami-00b3234e97386251c]
data.aws_ecr_repository.ecr_repository: Read complete after 2s [id=spahi4-photo-app]
aws_db_instance.default: Refreshing state... [id=db-EDU3COYGKMHFJV4PMSJAAPYH3I]
null_resource.db_init: Refreshing state... [id=8660641436548500519]
aws_s3_bucket_ownership_controls.image-storage: Refreshing state... [id=spahi4-photo-images-prod]
aws_s3_bucket_public_access_block.image-storage: Refreshing state... [id=spahi4-photo-images-prod]
aws_s3_bucket_versioning.image-storage: Refreshing state... [id=spahi4-photo-images-prod]
aws_s3_bucket_cors_configuration.image-storage: Refreshing state... [id=spahi4-photo-images-prod]
aws_iam_policy.image_storage_policy: Refreshing state... [id=arn:aws:iam::851893752920:policy/production_S3UploadPolicy]
aws_instance.app: Refreshing state... [id=i-0016a1524569ae5da]
aws_s3_bucket_public_access_block.client: Refreshing state... [id=spahi4.me]
aws_s3_bucket_website_configuration.client: Refreshing state... [id=spahi4.me]
data.aws_iam_policy_document.s3_bucket_policy_public: Reading...
data.aws_iam_policy_document.s3_bucket_policy_public: Read complete after 0s [id=1563853790]
aws_iam_policy_attachment.instance_s3_upload_attachment: Refreshing state... [id=production_InstanceS3UploadAttachment]
aws_s3_bucket_policy.client_policy: Refreshing state... [id=spahi4.me]
cloudflare_record.s3_website: Refreshing state... [id=cc316305dc17947b396284e8c7927f7e]
aws_eip.app: Refreshing state... [id=eipalloc-051f80094fe233d32]
cloudflare_record.ecs_api: Refreshing state... [id=cb8d5bf8aad2ae97a1c5bcc133aaf88a]

Terraform used the selected providers to generate the following execution
plan. Resource actions are indicated with the following symbols:
  ~ update in-place
-/+ destroy and then create replacement
 <= read (data resources)

Terraform will perform the following actions:

  # data.template_file.environment will be read during apply
  # (depends on a resource or a module with changes pending)
 <= data "template_file" "environment" {
      + id       = (known after apply)
      + rendered = (known after apply)
      + template = <<-EOT
            DEPLOYMENT=${deployment}
            NODE_ENV=production
            
            DATABASE_URL=${database_url}
            ROOT_DATABASE_URL=${root_database_url}
            S3_BUCKET_REGION=${s3_bucket_region}
            S3_BUCKET_NAME=${s3_bucket_name}
            
            API_ORIGIN=${api_origin}
            API_PORT=${api_port}
            WEB_ORIGIN=${web_origin}
            
            JWT_PUBLIC_KEY=${jwt_public_key}
            JWT_SECRET_KEY=${jwt_secret_key}
            
            SSL_CERT=${ssl_cert}
            SSL_KEY=${ssl_key}
            
            GOOGLE_REFRESH_TOKEN=${google_refresh_token}
            
            INSTALLED_GOOGLE_CLIENT_ID=${installed_google_client_id}
            INSTALLED_GOOGLE_CLIENT_SECRET=${installed_google_client_secret}
            INSTALLED_GOOGLE_REDIRECT_URI=${installed_google_redirect_uri}
            
            WEB_GOOGLE_CLIENT_ID=${web_google_client_id}
            WEB_GOOGLE_CLIENT_SECRET=${web_google_client_secret}
            WEB_GOOGLE_REDIRECT_URI=${web_google_redirect_uri}
        EOT
      + vars     = {
          + "api_origin"                     = "https://api.spahi4.me"
          + "api_port"                       = "443"
          + "database_url"                   = (sensitive value)
          + "deployment"                     = "production"
          + "google_refresh_token"           = (sensitive value)
          + "installed_google_client_id"     = (sensitive value)
          + "installed_google_client_secret" = (sensitive value)
          + "installed_google_redirect_uri"  = (sensitive value)
          + "jwt_public_key"                 = (sensitive value)
          + "jwt_secret_key"                 = (sensitive value)
          + "root_database_url"              = (sensitive value)
          + "s3_bucket_name"                 = "spahi4-photo-images-prod"
          + "s3_bucket_region"               = "eu-north-1"
          + "ssl_cert"                       = (sensitive value)
          + "ssl_key"                        = (sensitive value)
          + "web_google_client_id"           = (sensitive value)
          + "web_google_client_secret"       = (sensitive value)
          + "web_google_redirect_uri"        = (sensitive value)
          + "web_origin"                     = "https://spahi4.me"
        }
    }

  # data.template_file.init will be read during apply
  # (config refers to values not yet known)
 <= data "template_file" "init" {
      + id       = (known after apply)
      + rendered = (known after apply)
      + template = <<-EOT
            #!/bin/bash
            yum update -y
            amazon-linux-extras install -y docker
            service docker start
            usermod -a -G docker ec2-user
            chkconfig docker on
            echo "${env}" > /home/environment.env
            
            aws ecr get-login-password --region ${aws_region} | docker login --username AWS --password-stdin ${repository_url}
            
            docker pull ${repository_url}:server-"${git_sha}"
            docker pull ${repository_url}:worker-"${git_sha}"
            docker pull ${repository_url}:migrate-"${git_sha}"
            
            docker run -d -p 443:443 --restart=always \
              --env-file /home/environment.env \
              "${repository_url}":server-"${git_sha}"
            
            sudo docker run -d --restart=always \
                --env-file /home/environment.env \
              ${repository_url}:worker-"${git_sha}"
            
            sudo docker run -d \
                --env-file /home/environment.env \
              ${repository_url}:migrate-"${git_sha}"
        EOT
      + vars     = {
          + "aws_region"     = "eu-north-1"
          + "env"            = (known after apply)
          + "git_sha"        = "246620d2307809a6175847f1fe8c1a3cd5869a58"
          + "repository_url" = "851893752920.dkr.ecr.eu-north-1.amazonaws.com/spahi4-photo-app"
        }
    }

  # aws_db_instance.default will be updated in-place
  ~ resource "aws_db_instance" "default" {
      ~ engine_version                        = "15.7" -> "15.5"
        id                                    = "db-EDU3COYGKMHFJV4PMSJAAPYH3I"
        tags                                  = {
            "Name" = "photo-app-production"
        }
        # (63 unchanged attributes hidden)
    }

  # aws_eip.app will be updated in-place
  ~ resource "aws_eip" "app" {
        id                       = "eipalloc-051f80094fe233d32"
      ~ instance                 = "i-0016a1524569ae5da" -> (known after apply)
        tags                     = {}
        # (15 unchanged attributes hidden)
    }

  # aws_instance.app must be replaced
-/+ resource "aws_instance" "app" {
      ~ ami                                  = "ami-049700179228bce36" -> "ami-00b3234e97386251c" # forces replacement
      ~ arn                                  = "arn:aws:ec2:eu-north-1:851893752920:instance/i-0016a1524569ae5da" -> (known after apply)
      ~ associate_public_ip_address          = true -> (known after apply)
      ~ availability_zone                    = "eu-north-1b" -> (known after apply)
      ~ cpu_core_count                       = 1 -> (known after apply)
      ~ cpu_threads_per_core                 = 2 -> (known after apply)
      ~ disable_api_stop                     = false -> (known after apply)
      ~ disable_api_termination              = false -> (known after apply)
      ~ ebs_optimized                        = false -> (known after apply)
      - hibernation                          = false -> null
      + host_id                              = (known after apply)
      + host_resource_group_arn              = (known after apply)
      ~ id                                   = "i-0016a1524569ae5da" -> (known after apply)
      ~ instance_initiated_shutdown_behavior = "stop" -> (known after apply)
      + instance_lifecycle                   = (known after apply)
      ~ instance_state                       = "running" -> (known after apply)
      ~ ipv6_address_count                   = 0 -> (known after apply)
      ~ ipv6_addresses                       = [] -> (known after apply)
      ~ monitoring                           = false -> (known after apply)
      + outpost_arn                          = (known after apply)
      + password_data                        = (known after apply)
      + placement_group                      = (known after apply)
      ~ placement_partition_number           = 0 -> (known after apply)
      ~ primary_network_interface_id         = "eni-01ed29f293f353898" -> (known after apply)
      ~ private_dns                          = "ip-172-31-36-90.eu-north-1.compute.internal" -> (known after apply)
      ~ private_ip                           = "172.31.36.90" -> (known after apply)
      ~ public_dns                           = "ec2-16-171-246-92.eu-north-1.compute.amazonaws.com" -> (known after apply)
      ~ public_ip                            = "16.171.246.92" -> (known after apply)
      ~ secondary_private_ips                = [] -> (known after apply)
      ~ security_groups                      = [
          - "prod-allow_ec2",
          - "prod-allow_ec2_ssh",
          - "prod-allow_rds",
        ] -> (known after apply)
      + spot_instance_request_id             = (known after apply)
      ~ subnet_id                            = "subnet-0de5ef889581dad5d" -> (known after apply)
        tags                                 = {
            "Name" = "photo-app-production"
        }
      ~ tenancy                              = "default" -> (known after apply)
      ~ user_data                            = "0d81584937d2b25b92794087aecca4c15d96f61f" -> (known after apply) # forces replacement
      + user_data_base64                     = (known after apply)
        # (8 unchanged attributes hidden)

      ~ capacity_reservation_specification (known after apply)
      - capacity_reservation_specification {
          - capacity_reservation_preference = "open" -> null
        }

      ~ cpu_options (known after apply)
      - cpu_options {
          - core_count       = 1 -> null
          - threads_per_core = 2 -> null
            # (1 unchanged attribute hidden)
        }

      - credit_specification {
          - cpu_credits = "unlimited" -> null
        }

      ~ ebs_block_device (known after apply)

      ~ enclave_options (known after apply)
      - enclave_options {
          - enabled = false -> null
        }

      ~ ephemeral_block_device (known after apply)

      ~ instance_market_options (known after apply)

      ~ maintenance_options (known after apply)
      - maintenance_options {
          - auto_recovery = "default" -> null
        }

      ~ metadata_options (known after apply)
      - metadata_options {
          - http_endpoint               = "enabled" -> null
          - http_protocol_ipv6          = "disabled" -> null
          - http_put_response_hop_limit = 1 -> null
          - http_tokens                 = "optional" -> null
          - instance_metadata_tags      = "disabled" -> null
        }

      ~ network_interface (known after apply)

      ~ private_dns_name_options (known after apply)
      - private_dns_name_options {
          - enable_resource_name_dns_a_record    = false -> null
          - enable_resource_name_dns_aaaa_record = false -> null
          - hostname_type                        = "ip-name" -> null
        }

      ~ root_block_device (known after apply)
      - root_block_device {
          - delete_on_termination = true -> null
          - device_name           = "/dev/xvda" -> null
          - encrypted             = false -> null
          - iops                  = 100 -> null
          - tags                  = {} -> null
          - throughput            = 0 -> null
          - volume_id             = "vol-084f6157e2763f4cb" -> null
          - volume_size           = 8 -> null
          - volume_type           = "gp2" -> null
            # (1 unchanged attribute hidden)
        }
    }

Plan: 1 to add, 2 to change, 1 to destroy.

─────────────────────────────────────────────────────────────────────────────

Note: You didn't use the -out option to save this plan, so Terraform can't
guarantee to take exactly these actions if you run "terraform apply" now.

Pusher: @SPAHI4, Action: pull_request, Working Directory: terraform, Workflow: Lint & Tests

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants