Typescripted API for More information about how using TypeScript here: https://www.typescriptlang.org/docs/handbook
Notable packages (on master branch):
- Typescript
- Restify
- octokit/rest (for Github SDK v3)
Developer remarks:
- Github has released a 4th version of its API which uses Graphql to query the back and to fetch results. I've take a look on Apollo project ( https://github.com/apollographql/apollo-client ) which allow developers querying with Graphql but unfortunatly I was missing time to complete the project. To finish it, it was more reasonable to search for a SDK. That's how I proceeded and I finally used octokit/github which had a great and a huge community on Github, as a Github public SDK.
- I also created another branch on which I have implemented (at about 90% back-side but not started yet on the front) a solution to keep all repository that have been selected by users. The goal is multiple: track user and gain data about its preferences (famous repos vs. unknown according to the stars count of the repos or even if the user prefers the Java as the .NET etc.). A second idea is to keep the ID of a request and it's allow keeping the url of the search as a UUID key whereas the current B64 hash of the repo name and owner...
GET /repositories?search={search-input}[&page={page-no}]
Example for "Boot" like "Bootstrap"...
[
{
"id": 2126244,
"name": "bootstrap",
"description": "The most popular HTML, CSS, and JavaScript framework for developing responsive, mobile first projects on the web.",
"language": "CSS",
"starsCount": 123091,
"url": "https://api.github.com/repos/twbs/bootstrap",
"owner": {
"name": "twbs",
"pictureUrl": "https://avatars0.githubusercontent.com/u/2918581?v=4"
}
},
{
"id": 23069399,
"name": "bootstrap-material-design",
"description": "Material design theme for Bootstrap 3 and 4",
"language": "CSS",
"starsCount": 19132,
"url": "https://api.github.com/repos/FezVrasta/bootstrap-material-design",
"owner": {
"name": "FezVrasta",
"pictureUrl": "https://avatars2.githubusercontent.com/u/5382443?v=4"
}
},
// ...
]
GET /users/{repo-owner}/repositories/{repo-name}/metrics[?page={page-no}]
Example for the "mistergift-front" repository for user "christophedebatz". Used to get the repartition of the implications of each developers who participated to a project. Each page contains about 100 commits, dispatched over their authors.
{
"commitsCount": 79,
"details": [
{
"commitsCount": 77,
"ratio": 97.47,
"user": {
"name": "joulse",
"email": "[email protected]",
"pictureUrl": "https://avatars2.githubusercontent.com/u/5382443?v=4",
"profileUrl": "https://github.com/christophedebatz"
}
},
{
"commitsCount": 1,
"ratio": 1.27,
"user": {
"name": "Christophe de Batz",
"email": "[email protected]",
"pictureUrl": "https://avatars2.githubusercontent.com/u/5382443?v=4",
"profileUrl": "https://github.com/christophedebatz"
}
},
{
"commitsCount": 1,
"ratio": 1.27,
"user": {
"name": "polem",
"email": "[email protected]"
"pictureUrl": "https://avatars2.githubusercontent.com/u/5382443?v=4",
"profileUrl": "https://github.com/christophedebatz"
}
},
// ...
]
}
GET /users/{repo-owner}/repositories/{repo-name}/commits[?page={page-no}]
Used to get the last commits of the given repository (all branches concerned, obviously ordered by commit date). Each page serve about 100 commits.
[
{
"sha": "3958e8e3213647d49244b7b0cc129865e1e5d9b2",
"message": "feat(translation): add translation flag into search service",
"creationDate": "2018-03-26T14:31:56Z",
"author": {
"name": "chris15",
"email": "[email protected]",
"pictureUrl": "https://avatars2.githubusercontent.com/u/5382443?v=4",
"profileUrl": "https://github.com/chrissou"
}
},
{
"sha": "3958e8e3213647d49244b7b0cc129865e1e5d9b2",
"message": "feat(translation): add translation flag into search service",
"creationDate": "2018-03-26T14:31:56Z",
"author": {
"name": "chris15",
"email": "[email protected]",
"pictureUrl": "https://avatars2.githubusercontent.com/u/5382443?v=4",
"profileUrl": "https://github.com/chrissou"
}
},
// ...
]