I am trying to count commits for many large github repos using the API, so I would like to avoid getting the entire list of commits (this way as an example: api.github.com/repos/jasonrudolph/keyboard/commits ) and counting them.
If I had the hash of the first (initial) commit , I could use this technique to compare the first commit to the latest and it happily reports the total_commits in between (so I'd need to add one) that way. Unfortunately, I cannot see how to elegantly get the first commit using the API.
The base repo URL does give me the created_at (this url is an example: api.github.com/repos/jasonrudolph/keyboard ), so I could get a reduced commit set by limiting the commits to be until the create date (this url is an example: api.github.com/repos/jasonrudolph/keyboard/commits?until=2013-03-30T16:01:43Z) and using the earliest one (always listed last?) or maybe the one with an empty parent (not sure about if forked projects have initial parent commits).
Any better way to get the first commit hash for a repo?
Better yet, this whole thing seems convoluted for a simple statistic, and I wonder if I'm missing something. Any better ideas for using the API to get the repo commit count?
Edit: This somewhat similar question is trying to filter by certain files (" and within them to specific files."), so has a different answer.
If you're looking for the total number of commits in the default branch, you might consider a different approach.
Use the Repo Contributors API to fetch a list of all contributors:
https://developer.github.com/v3/repos/#list-contributors
Each item in the list will contain a contributions
field which tells you how many commits the user authored in the default branch. Sum those fields across all contributors and you should get the total number of commits in the default branch.
The list of contributors if often much shorter than the list of commits, so it should take fewer requests to compute the total number of commits in the default branch.