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

How to create nexus cleanup policy #226

Open
SomniVertix opened this issue May 27, 2022 · 9 comments
Open

How to create nexus cleanup policy #226

SomniVertix opened this issue May 27, 2022 · 9 comments
Assignees
Labels
enhancement New feature or request exempt-from-stale Exception label for stale bot

Comments

@SomniVertix
Copy link

Describe the bug
Not sure if its a bug or if I'm just missing something, but I can't seem to find where to define/create cleanup policies?

Expected behavior
Use of terraform provider to cleanup policies

@SomniVertix SomniVertix added the bug Something isn't working label May 27, 2022
@anmoel anmoel added enhancement New feature or request blocked This issue is blocked by external resources and removed bug Something isn't working labels Jun 15, 2022
@anmoel
Copy link
Member

anmoel commented Jun 15, 2022

hi @SomniVertix.

This is not a bug. It's a feature request.
But unfortunately no cleanup policies can be created via the REST API yet.
I will create a feature request at sonatype

@anmoel
Copy link
Member

anmoel commented Jun 15, 2022

please votes there: https://ideas.sonatype.com/ideas/IDEAS-I-1466

@github-actions
Copy link

This issue has been automatically marked as stale because it has had no activity in the last 90 days. It will be closed in 7 days if no further activity occurs. Leaving a comment starting with /fresh will mark this issue as not stale.

@github-actions github-actions bot added the stale label Oct 25, 2022
@anmoel anmoel added exempt-from-stale Exception label for stale bot and removed stale labels Oct 25, 2022
@onedr0p
Copy link

onedr0p commented Dec 28, 2022

This is the public issue that is tracking the status.
https://issues.sonatype.org/browse/NEXUS-17671

@scop
Copy link

scop commented Aug 3, 2023

Upstream issue moved to sonatype/nexus-public#149

@NickWemekamp
Copy link

As of Nexus 3.70 there is an API for clean up policies

@anmoel anmoel removed the blocked This issue is blocked by external resources label Aug 8, 2024
@anmoel anmoel moved this from Needs triage to Low priority in Nexus Terraform Provider Aug 8, 2024
@alexandrovas
Copy link

image

Only Nexus Pro feature 🥲

@chris-ruecker chris-ruecker self-assigned this Sep 12, 2024
@kellervater
Copy link

Found a super hacky terraform-onlyISH way to circumvent this limitation by leveraging the scripts feature.
If it helps you, feel free to use it:

################ SCRIPTS ########################
# Unfortunately Nexus OSS doesn't provide a REST Endpoint in the free version to manage cleanup policies.
# But since they are a crucial part for a full-auto GitOps management, 
# we include the groovy script from our former Ansible solution here.
data "http" "cleanup_policy_script" {
  url = "https://raw.githubusercontent.com/ansible-ThoTeam/nexus3-oss/refs/tags/v2.5.2/files/groovy/create_cleanup_policies_from_list.groovy"
}

# upload the groovy script to Nexus
resource "nexus_script" "cleanup_policy_script" {
  name = local.script_name
  content = data.http.cleanup_policy_script.response_body
  type = "groovy"
}

# define cleanup policies
locals {
  script_name = "create_cleanup_policies_from_list"
  cleanup_policies = [{
    name = "delete_old"
    format = "maven2"
    notes = "Automatically delete old assets 30 days after downloading."
    criteria = {
      lastDownloaded = 30
    }
  }]
}

# Due to the nature of the `data` block when using the `http` provider
# the POST request would already happen during the plan phase.
# The null_resource prevents this, since it will always change
# and the http data block depends on it.
resource "null_resource" "ok_to_be_replaced" {
  triggers = {
    always_change = "${timestamp()}"
  }
}
data "http" "upload_cleanup_policy" {
  depends_on = [ nexus_script.cleanup_policy_script, local.cleanup_policies, null_resource.ok_to_be_replaced ]
  url    = "${local.nexus_url}/service/rest/v1/script/${local.script_name}/run"
  method = "POST"
  request_headers = {
    Content-Type: "text/plain"
    authorization = "Basic ${base64encode("${local.nexus_username}:${local.nexus_password}")}"
  }

  request_body = jsonencode(local.cleanup_policies)

  lifecycle {
    postcondition {
      condition = contains([200], self.status_code)
      error_message = "Something went wrong uploading cleanup policies. Response (Code ${self.status_code}): ${self.response_body}"
    }
  }
}

Important

You'll need to provide some variables like nexus_url and credentials if applicable.

@threadcrux
Copy link

#226 (comment)
Great workaround, it would be nice to have the schema/definitions on the repository resources so the two can be correlated.

Cleanup policy is here: #481, but the resource schemas don't have resource policies define

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request exempt-from-stale Exception label for stale bot
Projects
Status: In process
Development

No branches or pull requests

9 participants