forked from UBC-MDS/gitBusy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgitBusy.Rmd
59 lines (46 loc) · 1.72 KB
/
gitBusy.Rmd
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
---
title: "gitBusy API Wrapper in R"
author: "Abishek Murali, Avinash Prabhakaran, Sid Arora, Ivan Despot"
date: "`r Sys.Date()`"
output: rmarkdown::html_vignette
vignette: >
%\VignetteIndexEntry{Vignette Title}
%\VignetteEngine{knitr::rmarkdown}
%\VignetteEncoding{UTF-8}
---
```{r setup, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>"
)
```
```{r}
suppressPackageStartupMessages(library(httr))
suppressPackageStartupMessages(library(gitBusy))
```
In this package - gitBusy - we provide an API wrapper for Github. It allows the user to obtain a list of Github organizations and their respective members, as well as the open repositories under each user, and the coding language they prefer to work in. Why is this useful? This package allows users to quickly access and analyze Github's vast network of organizations, users, and repositories.
## Example of Use:
Create the token using Key and Secret obtained from GitHub.com as shown in the code below:
```{r}
key <- as.character(Sys.getenv("KEY"))
secret <- as.character(Sys.getenv("SECRET"))
token <- gh_auth(key, secret)
```
```{r}
organization_name <- "UBC-MDS"
org_repos(organization_name, auth = T, token)
```
If you are interested in the public users and their most commonly used language, you can run the follow code to return a dataframe:
```{r}
organization_members(organization_name, auth = T, token)
```
Our package also allows you to return the number of public repositories for a given ID, with the following function:
```{r}
user_name <- "sarora"
repo_count(user_name, auth = T, token)
```
Finally, you may generate a dataframe of a particular user's language preferences in Github.
```{r}
id <- "Ivan-Despot"
user_preferences(id, token)
```