1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
# frozen_string_literal: true
module Octokit
class Client
# Methods for the Repository Statistics API
#
# @see https://developer.github.com/v3/repos/statistics/
module Stats
# Get contributors list with additions, deletions, and commit counts
#
# @param repo [Integer, String, Hash, Repository] A GitHub repository
# @option retry_timeout [Number] How long Octokit should keep trying to get stats (in seconds)
# @option retry_wait [Number] How long Octokit should wait between retries.
# @return [Array<Sawyer::Resource>] Array of contributor stats
# @see https://developer.github.com/v3/repos/statistics/#get-contributors-list-with-additions-deletions-and-commit-counts
# @example Get contributor stats for octokit
# @client.contributors_stats('octokit/octokit.rb')
def contributors_stats(repo, options = {})
get_stats(repo, 'contributors', options)
end
alias contributor_stats contributors_stats
# Get the last year of commit activity data
#
# @param repo [Integer, String, Hash, Repository] A GitHub repository
# @option retry_timeout [Number] How long Octokit should keep trying to get stats (in seconds)
# @option retry_wait [Number] How long Octokit should wait between retries.
# @return [Array<Sawyer::Resource>] The last year of commit activity grouped by
# week. The days array is a group of commits per day, starting on Sunday.
# @see https://developer.github.com/v3/repos/statistics/#get-the-last-year-of-commit-activity-data
# @example Get commit activity for octokit
# @client.commit_activity_stats('octokit/octokit.rb')
def commit_activity_stats(repo, options = {})
get_stats(repo, 'commit_activity', options)
end
# Get the number of additions and deletions per week
#
# @param repo [Integer, String, Hash, Repository] A GitHub repository
# @option retry_timeout [Number] How long Octokit should keep trying to get stats (in seconds)
# @option retry_wait [Number] How long Octokit should wait between retries.
# @return [Array<Sawyer::Resource>] Weekly aggregate of the number of additions
# and deletions pushed to a repository.
# @see https://developer.github.com/v3/repos/statistics/#get-the-number-of-additions-and-deletions-per-week
# @example Get code frequency stats for octokit
# @client.code_frequency_stats('octokit/octokit.rb')
def code_frequency_stats(repo, options = {})
get_stats(repo, 'code_frequency', options)
end
# Get the weekly commit count for the repo owner and everyone else
#
# @param repo [Integer, String, Hash, Repository] A GitHub repository
# @option retry_timeout [Number] How long Octokit should keep trying to get stats (in seconds)
# @option retry_wait [Number] How long Octokit should wait between retries.
# @return [Sawyer::Resource] Total commit counts for the owner and total commit
# counts in all. all is everyone combined, including the owner in the last
# 52 weeks. If you’d like to get the commit counts for non-owners, you can
# subtract all from owner.
# @see https://developer.github.com/v3/repos/statistics/#get-the-weekly-commit-count-for-the-repository-owner-and-everyone-else
# @example Get weekly commit counts for octokit
# @client.participation_stats("octokit/octokit.rb")
def participation_stats(repo, options = {})
get_stats(repo, 'participation', options)
end
# Get the number of commits per hour in each day
#
# @param repo [Integer, String, Hash, Repository] A GitHub repository
# @option retry_timeout [Number] How long Octokit should keep trying to get stats (in seconds)
# @option retry_wait [Number] How long Octokit should wait between retries.
# @return [Array<Array>] Arrays containing the day number, hour number, and
# number of commits
# @see https://developer.github.com/v3/repos/statistics/#get-the-number-of-commits-per-hour-in-each-day
# @example Get octokit punch card
# @octokit.punch_card_stats
def punch_card_stats(repo, options = {})
get_stats(repo, 'punch_card', options)
end
alias punch_card punch_card_stats
private
# @private Get stats for a repository
#
# @param repo [Integer, String, Hash, Repository] A GitHub repository
# @param metric [String] The metrics you are looking for
# @return [Array<Sawyer::Resource> or nil] Stats in metric-specific format, or nil if not yet calculated.
# @see https://developer.github.com/v3/repos/statistics/
def get_stats(repo, metric, options = {})
options = options.dup
if retry_timeout = options.delete(:retry_timeout)
retry_wait = options.delete(:retry_wait) || 0.5
timeout = Time.now + retry_timeout
end
loop do
data = get("#{Repository.path repo}/stats/#{metric}", options)
return data if last_response.status == 200
return [] if last_response.status == 204
return nil unless retry_timeout
return nil if Time.now >= timeout
sleep retry_wait if retry_wait
end
end
end
end
end
|