gpt4 book ai didi

ruby-on-rails - Octokit GitHub API

转载 作者:行者123 更新时间:2023-12-04 06:05:53 26 4
gpt4 key购买 nike

我想获取特定 GitHub 代表的拉取请求和问题的数量。目前我使用的方法真的很笨拙。

使用 octokit gem 和以下代码:

# Builds data that is sent to the API
def request_params
data = { }

# labels example: "bug,invalid,question"
data["labels"] = labels.present? ? labels : ""

# filter example: "assigned" "created" "mentioned" "subscribed" "all"
data["filter"] = filter

# state example: "open" "closed" "all"
data["state"] = state

return data
end


Octokit.auto_paginate = true
github = Octokit::Client.new(access_token: oauth_token)
github.list_issues("#{user}/#{repository}", request_params).count

接收到的数据非常大,所以在内存方面非常低效。我不需要关于问题的数据,只需要有多少问题,X 问题(基于过滤器/状态/标签)。

我想到了一个解决方案,但无法实现。基本上:做 1 个请求来获取标题,在标题中应该有一个指向最后一页的链接。然后再向最后一页发出 1 个请求,并检查有多少问题。然后我们可以计算:

count = ( number of pages * (issues-per-page - 1) ) + issues-on-last-page

但是我没有找到如何从octokit Authentificated Client获取请求头信息。如果有不用 octokit 的简单方法,我会很乐意使用它。

注意:我想解决这个问题,因为拉取请求的数量非常多,而且上面的代码在 Heroku 上会产生 R14 错误。

谢谢!

最佳答案

我觉得一个简单的方法是使用 GitHub API 并使用 per_page 过滤器限制您希望在页面中显示的 PR 的数量。例如:要找出 repo OneGet/oneget 的所有 PR,您可以使用.. https://api.github.com/search/issues?q=repo:OneGet/oneget+type:pr&per_page=1 。 JSON 响应具有字段“total_count”,它给出了 PR 总数的计数。由于只列出一个问题,因此响应会相对较轻。引用:Search Issues

关于ruby-on-rails - Octokit GitHub API,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45027921/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com