summaryrefslogtreecommitdiff
path: root/internal/codeberg
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2025-06-28 00:45:19 +0300
committerPaul Buetow <paul@buetow.org>2025-06-28 00:45:19 +0300
commit0c072d964d4d07e69d1c0af1f3b09f9adc543571 (patch)
tree64df6d5011ac946c0439fc98291e66a08d2e88f1 /internal/codeberg
parent921782160c1f07577035db56b5461a2edc3b30a8 (diff)
feat: add --delete-repo command to delete repositories from all organizations
- Added --delete-repo flag that accepts a repository name - Implemented DeleteRepo() methods in both GitHub and Codeberg API clients - Created HandleDeleteRepo handler with interactive confirmation - Shows clear status of repository across all configured organizations - Requires user to type "yes" to confirm deletion - Provides detailed feedback on success/failure for each deletion - Updated documentation and usage help 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
Diffstat (limited to 'internal/codeberg')
-rw-r--r--internal/codeberg/codeberg.go49
1 files changed, 49 insertions, 0 deletions
diff --git a/internal/codeberg/codeberg.go b/internal/codeberg/codeberg.go
index 4eaed66..e608016 100644
--- a/internal/codeberg/codeberg.go
+++ b/internal/codeberg/codeberg.go
@@ -248,3 +248,52 @@ func (c *Client) CreateRepo(repoName, description string, private bool) error {
return nil
}
+
+// DeleteRepo deletes a repository from Codeberg
+func (c *Client) DeleteRepo(repoName string) error {
+ if !c.HasToken() {
+ return fmt.Errorf("Codeberg token required to delete repository")
+ }
+
+ // First check if the repo exists
+ exists, err := c.RepoExists(repoName)
+ if err != nil {
+ return fmt.Errorf("failed to check if repo exists: %w", err)
+ }
+ if !exists {
+ // Repo doesn't exist, nothing to delete
+ return fmt.Errorf("repository %s/%s does not exist", c.org, repoName)
+ }
+
+ url := fmt.Sprintf("%s/repos/%s/%s", c.baseURL, c.org, repoName)
+
+ req, err := http.NewRequest("DELETE", url, nil)
+ if err != nil {
+ return err
+ }
+
+ req.Header.Set("Authorization", "token "+c.token)
+
+ resp, err := http.DefaultClient.Do(req)
+ if err != nil {
+ return err
+ }
+ defer resp.Body.Close()
+
+ if resp.StatusCode == 204 {
+ // Successfully deleted
+ return nil
+ } else if resp.StatusCode == 404 {
+ // Already gone, consider it a success
+ return nil
+ } else if resp.StatusCode == 403 {
+ body, _ := io.ReadAll(resp.Body)
+ return fmt.Errorf("permission denied (403): %s", string(body))
+ } else if resp.StatusCode == 401 {
+ body, _ := io.ReadAll(resp.Body)
+ return fmt.Errorf("authentication failed (401): %s", string(body))
+ }
+
+ body, _ := io.ReadAll(resp.Body)
+ return fmt.Errorf("failed to delete repository: status %d: %s", resp.StatusCode, string(body))
+}