PowerShellForGitHub

PowerShellForGitHub

PowerShell模块实现GitHub API命令行交互和自动化

PowerShellForGitHub是一个用于GitHub v3 API的PowerShell模块,提供命令行交互和自动化功能。该模块支持完整的管道操作,可在命令间传递数据。它涵盖广泛的GitHub API功能,包括仓库管理、问题跟踪和拉取请求处理。模块安装配置简便,适用于个人和企业用户,可高效执行GitHub自动化任务。

PowerShellForGitHubGitHub APIPowerShell模块自动化工具命令行交互Github开源项目

PowerShellForGitHub PowerShell 模块

[GitHub 版本] powershellgallery 下载量 GitHub 代码大小(字节) 下载量 CII 最佳实践 推文 <br /> 构建状态 Azure DevOps 测试 Azure DevOps 覆盖率 <br /> 需要帮助的问题 GitHub 最后提交

目录


概述

这是一个 PowerShell 模块,提供无状态的命令行交互和自动化 GitHub v3 API

充分利用 PowerShell 的优势,它完全支持管道,允许你将几乎任何命令的输出通过管道传递到模块内的任何其他命令。


新特性

查看 CHANGELOG.md 以了解当前版本以及所有过去版本的详细信息。


当前 API 支持

目前,此模块可以:

  • 查询、创建、更新和删除 仓库,包括
    • 查询、创建和删除 分支,以及相关的分支保护规则。
    • 查询和创建新的 复刻
    • 查询和创建仓库中的 内容
    • 查询仓库中的语言和标签,以及查询/更新其主题。
    • 更改仓库所有权。
    • 查询、启用和禁用安全和漏洞警报。
    • 查询和设置 GitHub Actions 权限。
    • 查询、设置和移除团队权限。
    • 查询各种 流量报告,包括引荐来源和路径、页面浏览量和克隆次数。
  • 查询、创建、编辑、锁定/解锁 问题 及其所有相关属性:
  • 查询和创建 拉取请求
  • 查询 协作者
  • 查询 贡献者
  • 查询 组织 及其成员。
  • 查询和更新 用户
  • 查询、创建、编辑和删除 团队,以及查询其成员。
  • 查询、创建、编辑和删除 项目,以及 项目列项目卡
  • 查询、创建、编辑和删除 发布 及相关内容/资产。
  • 查询、创建、编辑、删除、复刻和(取消)标星 gist,以及 gist 评论。
  • 查询、编辑和删除问题和拉取请求上的 反应
  • 查询、创建、编辑和删除 部署环境
  • 其他功能:

开发仍在进行中,目标是为整个 API 集添加广泛支持。

要全面了解还有哪些工作需要完成以实现 API 完整性,请参阅 Issue #70

查看 示例 以了解如何使用该模块完成这些任务。


安装

你可以在 PowerShell Gallery 获取 PowerShellForGitHub 的最新版本

Install-Module -Name PowerShellForGitHub

配置

为避免 GitHub 严格的 API 速率限制,你应该使用自己的个人访问令牌配置模块。

  1. 通过访问 https://github.com/settings/tokens/new 创建新的 API 令牌(提供描述并选择任何适当的范围)
  2. 调用 Set-GitHubAuthentication,输入任意用户名(用户名会被忽略,但弹出的对话框需要填写),并粘贴 API 令牌作为密码。这将安全地缓存到磁盘,并在所有未来的 PowerShell 会话中持续存在。 如果你将来想要清除它,只需调用 Clear-GitHubAuthentication)。

对于动态获取身份验证所需访问令牌的自动化场景(如GitHub Actions),请参考Get-Help Set-GitHubAuthentication -Examples中的示例2,了解如何以无提示方式进行配置。

另外,你_可以_通过设置$PSDefaultParameterValues["*-GitHub*:AccessToken"] = "<访问令牌>"来配置PowerShell本身,使其始终向任何命令传递明文访问令牌,但请注意这是不安全的(任何其他进程都可能访问这个明文值)。

这个模块还有许多额外的配置选项,可以通过Set-GitHubConfiguration为当前会话或所有未来会话进行配置。要全面了解所有可能的配置,请运行以下命令:

Get-Help Set-GitHubConfiguration -ShowWindow

例如,如果你经常在同一个仓库上工作,可以通过配置默认的OwnerName和/或RepositoryName来节省大量输入。你始终可以在单个命令中通过显式提供参数值来覆盖这些默认值,但在常见场景中,你可以减少输入量。

Set-GitHubConfiguration -DefaultOwnerName PowerShell Set-GitHubConfiguration -DefaultRepositoryName PowerShellForGitHub

请注意,某些命令中你可能只想提供OwnerName(比如当你调用Get-GitHubRepository并想查看特定用户拥有的所有仓库,而不是获取单个特定仓库时)。在这种情况下,如果你为这些值中的一个(或两个)设置了默认值,你需要显式传入$null作为相关参数值,以暂时覆盖你的默认设置。

还有更多出色的配置选项可用。请查看该命令的帮助以获取最新的列表!

GitHub Enterprise

要将配置设置为使用GitHub Enterprise服务器而不是GitHub.com,只需使用ApiHostName参数提供你的GitHub Enterprise服务器的主机名。

Set-GitHubConfiguration -ApiHostName "github.contoso.com"

使用方法

示例命令:

$issues = Get-GitHubIssue -Uri 'https://github.com/microsoft/PowerShellForGitHub'

更多示例命令,请参阅使用说明


开发和贡献

请参阅贡献指南了解如何开发和贡献。

如果你遇到任何问题,请查看GitHub Issues以确认是否已经讨论过。

如果你没有看到你的问题,请提交反馈


法律和许可

PowerShellForGitHub 使用 MIT 许可证授权。


治理

本项目的治理政策在此处描述。


行为准则

更多信息,请参阅行为准则


报告安全问题

请参阅SECURITY.md


隐私政策

更多信息,请参阅 Microsoft 的隐私政策

编辑推荐精选

博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

下拉加载更多