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

🚀 [Feature]: Add functions to manage Artifacts #334

Merged
merged 79 commits into from
Apr 1, 2025
Merged

Conversation

MariusStorhaug
Copy link
Member

@MariusStorhaug MariusStorhaug commented Mar 30, 2025

Description

This pull request introduces several enhancements and new features related to handling GitHub Actions artifacts, including a new PowerShell class and functions to manage artifacts.

Enhancements to Artifact Management:

  • Artifact class and format:

    • Added GitHubArtifact class to represent GitHub Actions artifacts with properties like DatabaseID, NodeID, Name, Owner, Repository, Size, Url, ArchiveDownloadUrl, Expired, Digest, CreatedAt, UpdatedAt, ExpiresAt, and WorkflowRun.
    • Added GitHubArtifact.Format.ps1xml to define a table view for displaying artifact properties in a structured format.
  • New public function for artifact management:

    • Get-GitHubArtifact: Retrieve GitHub Artifacts based on repo, workflow run or id.
    • Remove-GitHubArtifact: Removes a GitHub Artifact. Accepts a GitHub Artifact object via pipeline.
    • Save-GitHubArtifact: Downloads GitHub Artifacts by ID. Accepts a GitHub Artifact object via pipeline.
  • New private functions for artifact retrieval:

    • Added Get-GitHubArtifactById function to retrieve a specific artifact by its unique identifier.
    • Added Get-GitHubArtifactFromRepository function to list all artifacts for a given repository, with an option to include all versions.
    • Added Get-GitHubArtifactFromWorkflowRun function to list all artifacts from a specific workflow run, with an option to include all versions.

Type of change

  • 📖 [Docs]
  • 🪲 [Fix]
  • 🩹 [Patch]
  • ⚠️ [Security fix]
  • 🚀 [Feature]
  • 🌟 [Breaking change]

Checklist

  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas

@MariusStorhaug MariusStorhaug self-assigned this Mar 30, 2025
@Copilot Copilot bot review requested due to automatic review settings March 30, 2025 20:42
@MariusStorhaug MariusStorhaug requested a review from a team as a code owner March 30, 2025 20:42
Copy link

@Copilot Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

This PR updates the documentation for API function coverage related to managing Artifacts, reflecting the recently added functions. Key changes include updated counts for covered and missing functions, an increased overall coverage percentage, and modified endpoint statuses in the API endpoints table.

Files not reviewed (5)
  • src/classes/public/Artifacts/GitHubArtifact.ps1: Language not supported
  • src/formats/GitHubArtifact.Format.ps1xml: Language not supported
  • src/functions/private/Artifacts/Get-GitHubArtifactFromWorkflowRun.ps1: Language not supported
  • src/functions/public/API/Invoke-GitHubAPI.ps1: Language not supported
  • src/functions/public/Artifacts/Get-GitHubArtifact.ps1: Language not supported
Comments suppressed due to low confidence (2)

Coverage.md:313

  • Verify that the update from ':x:' to ':white_check_mark:' for the '/repos/{owner}/{repo}/actions/runs/{run_id}' endpoint accurately reflects the function coverage status after adding Artifact management functionalities.
| `/repos/{owner}/{repo}/actions/runs/{run_id}`                                                                             | :x:                | :white_check_mark: |                    |                    |                    |

Coverage.md:316

  • Confirm that changing the status from ':x:' to ':white_check_mark:' for the '/repos/{owner}/{repo}/actions/runs/{run_id}/artifacts' endpoint is intentional and reflects the new functionality coverage.
| `/repos/{owner}/{repo}/actions/runs/{run_id}/artifacts`                                                                   |                    | :white_check_mark: |                    |                    |                    |

MariusStorhaug and others added 20 commits March 30, 2025 23:32
…GitHubArtifact format for improved readability; enhance ZIP file download warning message
…nctions to enhance documentation and usability
…ave-GitHubArtifact functions for improved clarity and maintainability
…Save-GitHubArtifact to improve clarity and maintainability
…logic, including filename extraction and directory creation for improved functionality
…ndling and ensuring directory existence for improved reliability
…sure directory existence for enhanced reliability
…tions, and add Get-GitHubArtifactById and Get-GitHubArtifactFromRepository functions for improved artifact management
…th improved documentation and parameter handling
…pository and update status parameter handling in Get-GitHubWorkflowRun
@MariusStorhaug MariusStorhaug merged commit 82aae25 into main Apr 1, 2025
1 of 12 checks passed
@MariusStorhaug MariusStorhaug deleted the artifacts branch April 1, 2025 23:17
@github-actions github-actions bot restored the artifacts branch April 1, 2025 23:18
Copy link
Contributor

github-actions bot commented Apr 2, 2025

Module GitHub - 0.20.0 published to the PowerShell Gallery.

Copy link
Contributor

github-actions bot commented Apr 2, 2025

GitHub release for GitHub v0.20.0 has been created.

@MariusStorhaug MariusStorhaug deleted the artifacts branch April 2, 2025 15:34
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

1 participant