A GitHub API. Extracts data from GitHub into json style data.
Project description
⚠️ CAUTION: Note that this is a WIP, and is not yet perfected. There will be errors, and it would be appreciated if you let us know about it.
⚠️
**Version: 1.7.5
GitAPI: An API made for GitHub Stats!
About
About
GitAPI is an API made with python - styled with json - to make the data preferably easier to use. It is made up of posting json
requests, and retrieving that data from a function, and transfering that data into an output, in which you can use.
This API is designed to show GitHub stats for certain users, or viewing GitHub itself, in data form.
To learn how to use it, you can read the Usage header below.
Posts
The Replit post is located here
Languages used
Languages used to program this package were: Python3
Queries
Not all of the GitHub queries are in here, but if you wish to see all of them, go to this GitHub docs.
Contributers
- darkdarcool: More professionalized file-ing and helping with more GitHub Queries.
- Isaiah08-D: Adding comments, and letting us know of bug.
- jwodder: Finding the solution to the bug.
Usage
Installation
To install and use the package, you must first:
pip install git_api
This will install the package - git_api
(GitAPI) - and then you will be able to use it.
To then import it, you must put the following code:
import git_api
OR
import git_api as gitapi
OR
from git_api import *
For more information, go here.
Note that all of these methods work.
Usage
To use this package, first import it as shown above. Then create a python file - name it whatever you want, it doesn't matter.
Once you're done with that, open the file, and add the following example code:
import git_api
git_api.Token() # We'll place the personal access token here later on. For now, it'll be empty.
user_info = git_api.User("Username here").User() # Insert your username in the argument shown here.
print(user_info)
You've done it! But wait - it doesn't work, it only gives an error! The reason for this is that -
NUMBER 1: You need a personal access token which we'll discuss in a moment.
NUMBER 2: You need to have a GitHub username in mind and place it in the assigned space.
Let's start with number 1, creating the token.
1: The Token
To first create a token, you must create or use an existing GitHub account. If you already have a GitHub account, you can move on to the next section. However, if you are creating a new GitHub account, follow the instructions below:
#1: Go to https://github.com
and click sign up
.
#2: Once you've clicked that, just follow the instructions shown on the page.
#3: Then after that, you can either get used to GitHub and do this later, or do this immediately; Go to this document and read it thoroughly, as it holds the information to creating a personal token. Choose the categories you think will best fit for your project and finish up with the token.
#4: Note that this token should be kept private and not shared. If you are positive that this token will be private, then you can just copy and paste the token into a string (inside parentheses), and insert it into the token argument space. However, if you know that this will be shown to the public, create a .env
file, and paste the token inside there. Make sure you make it a variable, for example, like this:
token=blahblahblah
Also note that you can only copy the token once, so check that you actually copied down the token. Go back into your python file and copy/paste down the following code into the assigned space;
os.environ["token"] # Insert your .env variable here
NOTE: All GitAPI functions must have a token in order for it to work.
#5: Then you're pretty much done! Your final code example should look something like this:
2: Finale
import git_api
git_api.Token(os.environ["token"])
user_info = git_api.User("JBYT27").User()
print(user_info)
This will print some of the user's information.
Another cool thing you can do with this package is print a GitHub User's followers! Wanna try? Here we go!
1. Import the package
First, import the package as shown above. All you need to do is import git_api
. Or you can install from pip
and then do that. Let's go onto the next step.
2. Get the token
Remember how I said the token was important? Yeah, it really is. So it's step 2 ;) If you don't know how to create a token, it's written right above. So far, you should have something like this:
import git_api
import os
git_api.Token(os.environ["token"])
3. The function
Now we write the function. So to get a GitHub user's followers, it's a bit wonky. So the syntax for the function is git_api.UserFollower("USERNAME", "INTEGER").Followers()
. You replace the "USERNAME"
with a GitHub username and replace the "INTEGER"
with a string that has a integer number inside it to show how many followers should be shown. Note that this is returning the value, not printing it. So what you have to remember is that you have to print this variable or value in order for it to show.
Kinda confusing, right? Let me show you an example :)
import git_api # importing the package. Note that you can use `pip` as well
import os # using os package to get token from .env file
git_api.Token(os.environ["token"]) # retrieves the token so you can use it.
follower_data = git_api.UserFollower("JBYT27", "10").Followers() # the gitapi function to get data
print(follower_data) # prints data
So that will print a GitHub user's followers. If you want to show the users that a GitHub user is following, all you have to do is switch the function(UserFollower
) to UserFollowing
. So for following, it would look like this:
import git_api # importing the package. Note that you can use `pip` as well
import os # using os package to get token from .env file
git_api.Token(os.environ["token"]) # retrieves the token so you can use it.
following_data = git_api.UserFollowing("JBYT27", "10").Following() # the gitapi function to get data
print(following_data) # prints data
You can take a look at the code, or just play with it if you want to experiment with it :)
An example repl is listed here.
Contributing
Contributing will be listed mostly in the Code of Conduct, however for more info, visit the Contributing readme.
License
This package is under the MIT License
.
Projects
All of the projects involving or using this package is listed here.
Features:
- Add basic features for
User()
class - Add advanced features for
User()
class - Add basic functions for
GitHub()
class - Add advanced functions for
GitHub()
class - Add basic functions in package
- Add documentary for package
All functions:
git_api.User("username")
git_api.User("username").User()
git_api.User("username").Name()
git_api.User("username").Bio()
git_api.User("username").Name()
git_api.User("username").Email()
git_api.User("username").Avatar()
git_api.User("username").Account()
git_api.User("username").Admin()
git_api.User("username").Location()
git_api.User("username").Twitter()
git_api.User("username").Developer()
git_api.User("username").Userid()
git_api.User("username").PinnedItems()
git_api.User("username").Company()
git_api.UserFollower("username", "num_of_followers_shown")
git_api.UserFollower("username", "num_of_followers_shown").Followers()
git_api.UserFollowing("username", "num_of_following_shown")
git_api.UserFollowing("username", "num_of_following_shown").Following()
git_api.GitHub()
** Note that this class is a WIP**
git_api.GitHub.Status()
git_api.Repo("owner", "reponame")
git_api.Repo("owner", "reponame").Repo()
git_api.Repo("owner", "reponame").CreatedAt()
git_api.Repo("owner", "reponame").Databaseid()
git_api.Repo("owner", "reponame").Description()
git_api.Repo("owner", "reponame").Homepageurl()
git_api.Repo("owner", "reponame").Id()
git_api.Repo("owner", "reponame").IsArchived()
git_api.Repo("owner", "reponame").IsDisabled()
git_api.Repo("owner", "reponame").IsEmpty()
git_api.Repo("owner", "reponame").IsLocked()
git_api.Repo("owner", "reponame").IsPrivate()
git_api.Repo("owner", "reponame").Name()
git_api.Repo("owner", "reponame").Language()
git_api.Repo("owner", "reponame").Stars()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file git_api-1.7.5.tar.gz
.
File metadata
- Download URL: git_api-1.7.5.tar.gz
- Upload date:
- Size: 8.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/3.10.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.8.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 57ec1c2a731480ccb3b2a570d4fc4bc6c43d21a716cba5d887804dd5871e8dd9 |
|
MD5 | cd96947ec25f766166b2d3d059b4430d |
|
BLAKE2b-256 | 27bea783128b2becc5b4691b448b0984bce510afa79135be70a5adf1391336a3 |
File details
Details for the file git_api-1.7.5-py3-none-any.whl
.
File metadata
- Download URL: git_api-1.7.5-py3-none-any.whl
- Upload date:
- Size: 8.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/3.10.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.8.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 71a8c7e7b0a7ada2f2a6ad3bc69cb5713f156f6681b58b39b666d4b72b7d273c |
|
MD5 | 18a40bbffdacec7a5ff8045075f3c2fd |
|
BLAKE2b-256 | b5fe450cd3d0ca34ad2363c572caa9bfc694520a6b40314fd69ee9deec7c29cb |