This is an automated email from the ASF dual-hosted git repository.

tn pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/tooling-trusted-release.git


The following commit(s) were added to refs/heads/main by this push:
     new 0cfa9e8  Remove draft directory
0cfa9e8 is described below

commit 0cfa9e8753e5292f7f170979fdd1529104bcf464
Author: Thomas Neidhart <[email protected]>
AuthorDate: Mon Mar 31 10:21:32 2025 +0200

    Remove draft directory
---
 atr/routes/draft.py                 |  26 +----
 atr/templates/draft-directory.html  | 214 ------------------------------------
 atr/templates/includes/sidebar.html |   3 -
 3 files changed, 3 insertions(+), 240 deletions(-)

diff --git a/atr/routes/draft.py b/atr/routes/draft.py
index c33d68d..c1184b6 100644
--- a/atr/routes/draft.py
+++ b/atr/routes/draft.py
@@ -172,26 +172,6 @@ def _path_warnings_errors_metadata(
     return warnings, errors
 
 
[email protected]("/drafts")
-async def directory(session: routes.CommitterSession) -> str:
-    user_projects = await session.user_projects
-    user_candidate_drafts = await session.user_candidate_drafts
-
-    promote_form = await PromoteForm.create_form()
-    delete_form = await DeleteForm.create_form()
-
-    return await quart.render_template(
-        "draft-directory.html",
-        asf_id=session.uid,
-        projects=user_projects,
-        server_domain=session.host,
-        number_of_release_files=_number_of_release_files,
-        candidate_drafts=user_candidate_drafts,
-        promote_form=promote_form,
-        delete_form=delete_form,
-    )
-
-
 @routes.committer("/draft/add", methods=["GET", "POST"])
 async def add(session: routes.CommitterSession) -> response.Response | str:
     """Show a page to allow the user to rsync files to candidate drafts."""
@@ -213,7 +193,7 @@ async def add(session: routes.CommitterSession) -> 
response.Response | str:
             # TODO: Show the form with errors
             return await session.redirect(add, error="Invalid form data")
         await _add(session, form)
-        return await session.redirect(directory, success="Release candidate 
created successfully")
+        return await session.redirect(add, success="Release candidate created 
successfully")
 
     return await quart.render_template(
         "draft-add.html",
@@ -309,7 +289,7 @@ async def delete(session: routes.CommitterSession) -> 
response.Response:
         # TODO: Confirm that this is a bug, and report upstream
         await aioshutil.rmtree(draft_dir)  # type: ignore[call-arg]
 
-    return await session.redirect(directory, success="Candidate draft deleted 
successfully")
+    return await session.redirect(promote, success="Candidate draft deleted 
successfully")
 
 
 
@routes.committer("/draft/delete-file/<project_name>/<version_name>/<path:file_path>",
 methods=["POST"])
@@ -479,7 +459,7 @@ async def promote(session: routes.CommitterSession) -> str 
| response.Response:
                 await data.commit()
                 await aioshutil.move(source, target)
 
-                return await session.redirect(directory, success="Candidate 
draft successfully promoted to candidate")
+                return await session.redirect(promote, success="Candidate 
draft successfully promoted to candidate")
 
             except Exception as e:
                 logging.exception("Error promoting candidate draft:")
diff --git a/atr/templates/draft-directory.html 
b/atr/templates/draft-directory.html
deleted file mode 100644
index 3ca7e83..0000000
--- a/atr/templates/draft-directory.html
+++ /dev/null
@@ -1,214 +0,0 @@
-{% extends "layouts/base.html" %}
-
-{% block title %}
-  Release candidate drafts ~ ATR
-{% endblock title %}
-
-{% block description %}
-  Active release candidate drafts.
-{% endblock description %}
-
-{% block content %}
-  <h1>Release candidate draft directory</h1>
-  <p class="intro">
-    A <strong>candidate draft</strong> is an editable set of files which can 
be <strong>frozen and promoted into a candidate release</strong> for voting on 
by the PMC.
-  </p>
-  <ul>
-    <li>You can only create a new candidate draft if you are a member of the 
PMC</li>
-    <li>Projects can work on multiple candidate drafts for different versions 
simultaneously</li>
-    <li>A candidate draft is only editable until submitted for voting</li>
-  </ul>
-
-  <div class="row row-cols-1 row-cols-md-2 g-4 mb-5">
-    {% for release in candidate_drafts %}
-      {% set release_id = release.name.replace('.', '_') %}
-      <div class="col" id="{{ release.name }}">
-        <div class="card h-100">
-          <div class="card-header">
-            <h5 class="card-title">
-              {{ release.project.display_name }} {{ release.version }}&nbsp;
-              <span class="badge bg-success align-top">Draft</span>
-            </h5>
-            {% if release.project.committee %}
-              <h6 class="card-subtitle mb-2 text-muted">{{ 
release.project.committee.display_name }}</h6>
-            {% endif %}
-            <div class="position-absolute top-0 end-0 m-2">
-              <button class="btn btn-primary"
-                      data-bs-toggle="modal"
-                      data-bs-target="#promote-{{ release_id }}">
-                <i class="fa-solid fa-upload"></i>
-              </button>
-              <button class="btn btn-danger"
-                      data-bs-toggle="modal"
-                      data-bs-target="#delete-{{ release_id }}">
-                <i class="fa-solid fa-trash"></i>
-              </button>
-            </div>
-
-            <div class="modal modal-lg fade"
-                 id="promote-{{ release_id }}"
-                 data-bs-backdrop="static"
-                 data-bs-keyboard="false"
-                 tabindex="-1"
-                 aria-labelledby="promote-{{ release_id }}-label"
-                 aria-hidden="true">
-              <div class="modal-dialog border-primary">
-                <div class="modal-content">
-                  <div class="modal-header bg-primary bg-opacity-10 
text-primary">
-                    <h1 class="modal-title fs-5" id="promote-{{ release_id 
}}-label">Promote candidate draft to candidate</h1>
-                    <button type="button"
-                            class="btn-close"
-                            data-bs-dismiss="modal"
-                            aria-label="Close"></button>
-                  </div>
-                  <div class="modal-body">
-                    <p class="text-muted mb-3">Promoting will freeze this 
candidate draft into a candidate that can be voted on.</p>
-                    <form method="post" action="{{ 
as_url(routes.draft.promote) }}">
-                      {{ promote_form.hidden_tag() }}
-                      <input type="hidden" name="candidate_draft_name" 
value="{{ release.name }}" />
-                      <div class="mb-3">
-                        <div class="form-check">
-                          <input class="form-check-input"
-                                 id="confirm_promote_{{ release_id }}"
-                                 name="confirm_promote"
-                                 required=""
-                                 type="checkbox"
-                                 value="y"
-                                 onchange="updateButton(this, 
'promote-button-{{ release_id }}')" />
-                          <label class="form-check-label" 
for="confirm_promote_{{ release_id }}">
-                            I understand this will freeze the candidate draft 
into a candidate
-                          </label>
-                        </div>
-                      </div>
-                      <button type="submit"
-                              id="promote-button-{{ release_id }}"
-                              disabled
-                              class="btn btn-primary">Promote to 
candidate</button>
-                    </form>
-                  </div>
-                </div>
-              </div>
-            </div>
-            <div class="modal modal-lg fade"
-                 id="delete-{{ release_id }}"
-                 data-bs-backdrop="static"
-                 data-bs-keyboard="false"
-                 tabindex="-1"
-                 aria-labelledby="promote-{{ release_id }}-label"
-                 aria-hidden="true">
-              <div class="modal-dialog border-primary">
-                <div class="modal-content">
-                  <div class="modal-header bg-danger bg-opacity-10 
text-danger">
-                    <h1 class="modal-title fs-5" id="delete-{{ release_id 
}}-label">Delete candidate draft</h1>
-                    <button type="button"
-                            class="btn-close"
-                            data-bs-dismiss="modal"
-                            aria-label="Close"></button>
-                  </div>
-                  <div class="modal-body">
-                    <p class="text-muted mb-3">Warning: This action will 
permanently delete this candidate draft and cannot be undone.</p>
-                    <form method="post" action="{{ as_url(routes.draft.delete) 
}}">
-                      {{ delete_form.hidden_tag() }}
-                      <input type="hidden" name="candidate_draft_name" 
value="{{ release.name }}" />
-                      <div class="mb-3">
-                        <label for="confirm_delete_{{ release_id }}" 
class="form-label">
-                          Type <strong>DELETE</strong> to confirm:
-                        </label>
-                        <input class="form-control mt-2"
-                               id="confirm_delete_{{ release_id }}"
-                               name="confirm_delete"
-                               placeholder="DELETE"
-                               required=""
-                               type="text"
-                               value=""
-                               onkeyup="updateDeleteButton(this, 
'delete-button-{{ release_id }}')" />
-                      </div>
-                      <button type="submit"
-                              id="delete-button-{{ release_id }}"
-                              disabled
-                              class="btn btn-danger">Delete candidate 
draft</button>
-                    </form>
-                  </div>
-                </div>
-              </div>
-            </div>
-
-          </div>
-          <div class="card-body position-relative">
-            <p class="card-text">
-              {% if number_of_release_files(release) > 0 %}
-                This candidate draft has <a href="{{ 
as_url(routes.draft.review, project_name=release.project.name, 
version_name=release.version) }}">{{ number_of_release_files(release) }} 
file(s)</a>.
-              {% else %}
-                This candidate draft doesn't have any files yet.
-              {% endif %}
-              <a href="{{ as_url(routes.draft.add_project, 
project_name=release.project.name, version_name=release.version) }}">Upload a 
file using the browser</a>,
-              or use the command below to add or modify files in this draft:
-            </p>
-          </div>
-          <div class="card-footer bg-light border-1 pt-4 pb-4 
position-relative">
-            <button class="btn btn-sm btn-outline-secondary atr-copy-btn fs-6 
position-absolute top-0 end-0 m-2"
-                    data-clipboard-target="#cmd-{{ release.name|replace('.', 
'-') }}">
-              <i class="bi bi-clipboard"></i> Copy
-            </button>
-            <pre class="small mb-0" id="cmd-{{ release.name|replace('.', '-') 
}}">rsync -av -e 'ssh -p 2222' your/files/ \
-    {{ asf_id }}@{{ server_domain }}:/{{ release.project.name }}/{{ 
release.version }}/</pre>
-          </div>
-        </div>
-      </div>
-    {% endfor %}
-    {% if candidate_drafts|length == 0 %}
-      <div class="col-12">
-        <div class="alert alert-info">There are currently no candidate 
drafts.</div>
-      </div>
-    {% endif %}
-  </div>
-{% endblock content %}
-
-{% block javascripts %}
-  {{ super() }}
-  <script>
-      document.addEventListener("DOMContentLoaded", function() {
-          const copyButtons = document.querySelectorAll(".atr-copy-btn");
-
-          copyButtons.forEach(button => {
-              button.addEventListener("click", function() {
-                  const targetId = this.getAttribute("data-clipboard-target");
-                  const targetElement = document.querySelector(targetId);
-
-                  if (targetElement) {
-                      const textToCopy = targetElement.textContent;
-
-                      navigator.clipboard.writeText(textToCopy)
-                          .then(() => {
-                              const originalText = this.innerHTML;
-                              this.innerHTML = '<i class="bi bi-check2"></i> 
Copied!';
-
-                              // Reset the button text after 2000ms
-                              setTimeout(() => {
-                                  this.innerHTML = originalText;
-                              }, 2000);
-                          })
-                          .catch(err => {
-                              console.error("Failed to copy: ", err);
-                              this.innerHTML = '<i class="bi 
bi-exclamation-triangle"></i> Failed!';
-
-                              setTimeout(() => {
-                                  this.innerHTML = '<i class="bi 
bi-clipboard"></i> Copy';
-                              }, 2000);
-                          });
-                  }
-              });
-          });
-      });
-
-      function updateButton(checkboxElement, buttonId) {
-          let button = document.getElementById(buttonId);
-          button.disabled = !checkboxElement.checked;
-      }
-
-      function updateDeleteButton(inputElement, buttonId) {
-          let button = document.getElementById(buttonId);
-          button.disabled = inputElement.value !== "DELETE";
-      }
-  </script>
-{% endblock javascripts %}
diff --git a/atr/templates/includes/sidebar.html 
b/atr/templates/includes/sidebar.html
index 4f55ddb..925ba38 100644
--- a/atr/templates/includes/sidebar.html
+++ b/atr/templates/includes/sidebar.html
@@ -30,9 +30,6 @@
     {% if current_user %}
       <h3>Release candidate drafts</h3>
       <ul>
-        <li>
-          <a href="{{ as_url(routes.draft.directory) }}">Review drafts</a>
-        </li>
         <li>
           <a href="{{ as_url(routes.draft.add) }}">Add draft</a>
         </li>


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to