Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/brpaz/ulauncher-github

Ulauncher Extension that provides quick access to common GitHub functionality like your repositories or gists.
https://github.com/brpaz/ulauncher-github

github ulauncher ulauncher-extension

Last synced: about 1 month ago
JSON representation

Ulauncher Extension that provides quick access to common GitHub functionality like your repositories or gists.

Awesome Lists containing this project

README

        

# Ulauncher Github

> [ulauncher](https://ulauncher.io/) Extension that provides quick access to common [GitHub](https://github.com) functionality like your repositorie, assigned issues or Pull Requests and many more.
[![CI Status](https://img.shields.io/github/workflow/status/brpaz/ulauncher-github/CI?color=orange&label=actions&logo=github&logoColor=orange&style=for-the-badge)](https://github.com/brpaz/ulauncher-docker/workflows)
[![Ulauncher Extension](https://img.shields.io/badge/Ulauncher-Extension-green.svg?style=for-the-badge)](https://ext.ulauncher.io/-/github-brpaz-ulauncher-github)
![License](https://img.shields.io/github/license/brpaz/ulauncher-github.svg?style=for-the-badge)

## Usage

![demo](demo.gif)

## Features

- Quick access to your repositories and organizations.
- Access to your Issues and Pull Requests (Assigned, Created)
- Search public repos and users
- Search on [GitHub Documentation pages](https://docs.github.com/en)

## Getting started

### Pre-Requisites

This extension requires Python > 3 and a few python packages installed on your system.

To install them, you can run the following command, on your terminal:

```bash
pip install -r https://github.com/brpaz/ulauncher-github/blob/master/requirements.txt
```

### Install the extension

Open ulauncher preferences window -> extensions -> add extension and paste the following url:

`https://github.com/brpaz/ulauncher-github`

### Extension Settings

Before being able to start using the extension, you must generate a **Personal Access Token** (PAT) and configure it in the extension settings. The access token will allow the extension to access the GitHub API.

You can generate yours [here](https://github.com/settings/tokens). Make sure you select at least the permissions for "repo", "read:org", "gist", "user" and "notifications", otherwise you might see errors when using some specific commands in the extension.

## Usage

This extension provides various commands/keywords to access the different functionality. If you type `GitHub` in Ulauncher you should see the available commands.

![Extension Screenshot](./assets/screenshots/screenshot_1.png)

These include:

- GitHub: Search Repositories
- GitHub: Search Users
- GitHub: My Gists
- GitHub: My Organizations
- GitHub: My Assigned Issues
- GitHub: My Created Issues
- GitHub: My Assigned Pull Requests
- GitHub: My Created Pull Requests
- GitHub: My Notifications
- GitHub: My Repositories
- GitHub: My Account
- GitHub: Search Documentation
- GitHub: Extension Options

### Note on Cache

When the extension starts, it will download a list of all of your repositories, stars and gists and save them in a `json` file. This helps for performance reasons and GitHub API doesnΒ΄t have a way to search on your own and organizations repostories in the same request.

This information is cached for 1 day by default. You can clear your cache and trigger a reindex of the local data by restarting ulauncher or by going to `GitHub: Extension Options -> Refresh cache`.

Depending on the number of repositories you have access, this indexing process might take some time. It is executed in the background and you will receive a notification when the process finishes.

## Development

```
git clone https://github.com/brpaz/ulauncher-github
make link
```

The ```make link``` will create a symbolic link to the ulauncher extensions folder.

Next, stop Ulauncher if running and run the following command:

```
make dev
```

This will start Ulauncher from the command line with all extensions disabled. In the output you will see something like this:

```
VERBOSE=1 ULAUNCHER_WS_API=ws://127.0.0.1:5054/com.github.brpaz.ulauncher-github PYTHONPATH=/usr/lib/python3.8/site-packages /usr/bin/python3 /home/bruno/.local/share/ulauncher/extensions/com.github.brpaz.ulauncher-github/main.py
```

Run this, command in another terminal window, to laucnh the GitHub Extension.

## TODO

- Cache user repositories, gists and organizations in background for faster results.

## Contributing

Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated**.

1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request
## πŸ’› Support the project

If this project was useful to you in some form, I would be glad to have your support. It will help to keep the project alive and to have more time to work on Open Source.

The sinplest form of support is to give a ⭐️ to this repo.

You can also contribute with [GitHub Sponsors](https://github.com/sponsors/brpaz).

[![GitHub Sponsors](https://img.shields.io/badge/GitHub%20Sponsors-Sponsor%20Me-red?style=for-the-badge)](https://github.com/sponsors/brpaz)

Or if you prefer a one time donation to the project, you can simple:

Buy Me A Coffee
## πŸ“ License

Copyright Β© 2020 [Bruno Paz](https://github.com/brpaz).

This project is [MIT](https://opensource.org/licenses/MIT) licensed.