-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
3 changed files
with
211 additions
and
22 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,29 +1,218 @@ | ||
# HyprNotify | ||
A needless DBus implementation for `hyprctl notify` so I can use `notify-send`. | ||
<!-- Improved compatibility of back to top link: See: https://github.com/othneildrew/Best-README-Template/pull/73 --> | ||
<a name="readme-top"></a> | ||
<!-- | ||
*** Thanks for checking out the Best-README-Template. If you have a suggestion | ||
*** that would make this better, please fork the repo and create a pull request | ||
*** or simply open an issue with the tag "enhancement". | ||
*** Don't forget to give the project a star! | ||
*** Thanks again! Now go create something AMAZING! :D | ||
--> | ||
|
||
## Overview | ||
This implements a pseudo notification daemon, which **tries to** manage the state of Hyprland's internal notification manager. This requires the centuries-old advanced technology called "YOLO". | ||
|
||
Along with that, this also implements the `org.freedesktop.Notifications` DBus Name, so you can use utilities like `notify-send` to manage notifications. | ||
|
||
## Building & Running | ||
To build this "monstrosity", install the latest `go` compiler and type `go build ./cmd/hyprnotify` from the project root. | ||
<!-- PROJECT SHIELDS --> | ||
<!-- | ||
*** I'm using markdown "reference style" links for readability. | ||
*** Reference links are enclosed in brackets [ ] instead of parentheses ( ). | ||
*** See the bottom of this document for the declaration of the reference variables | ||
*** for contributors-url, forks-url, etc. This is an optional, concise syntax you may use. | ||
*** https://www.markdownguide.org/basic-syntax/#reference-style-links | ||
--> | ||
[![Contributors][contributors-shield]][contributors-url] | ||
[![Forks][forks-shield]][forks-url] | ||
[![Stargazers][stars-shield]][stars-url] | ||
[![Issues][issues-shield]][issues-url] | ||
[![MIT License][license-shield]][license-url] | ||
[![Go][golang-shield]][golang-url] | ||
|
||
To run just execute the binary `hyprnotify` | ||
## Demo | ||
data:image/s3,"s3://crabby-images/37122/371225a10331e3cbcc4e5847839dac2f51e9e2c4" alt="hyprnotify_demo" | ||
|
||
## TODO | ||
- [x] Implement the DBus Protocol | ||
- [x] Replace shell command invocation with IPC | ||
- [x] Implement Hint:urgency | ||
- [x] Implement Hint:x-hyprnotify-font-size | ||
- [ ] Implement Hint:x-hyprnotify-color | ||
- [ ] Add support for sound | ||
- [ ] Scrap the Project | ||
<!-- PROJECT LOGO --> | ||
<br /> | ||
<div align="center"> | ||
<a href="https://github.com/codelif/hyprnotify"> | ||
<img src="assets/logo.png" alt="Logo" width="80" height="80"> | ||
</a> | ||
|
||
## Why? | ||
No Reason in particular, just wanted to learn Go & DBus this week. | ||
<h3 align="center">Hyprnotify</h3> | ||
|
||
## How? | ||
By sacrificing everything I stood for. This thing is filled with race conditions. | ||
<p align="center"> | ||
A DBus Implementation for 'hyprctl notify' | ||
<br /> | ||
<br /> | ||
</p> | ||
</div> | ||
|
||
|
||
|
||
<!-- TABLE OF CONTENTS --> | ||
<details> | ||
<summary>Table of Contents</summary> | ||
<ol> | ||
<li> | ||
<a href="#about-the-project">About The Project</a> | ||
</li> | ||
<li> | ||
<a href="#getting-started">Getting Started</a> | ||
<ul> | ||
<li><a href="#prerequisites">Prerequisites</a></li> | ||
<li><a href="#compiling">Compiling</a></li> | ||
</ul> | ||
</li> | ||
<li><a href="#usage">Usage</a></li> | ||
<li><a href="#roadmap">Roadmap</a></li> | ||
<li><a href="#contributing">Contributing</a></li> | ||
<li><a href="#license">License</a></li> | ||
<li><a href="#contact">Contact</a></li> | ||
<li><a href="#acknowledgments">Acknowledgments</a></li> | ||
</ol> | ||
</details> | ||
|
||
|
||
|
||
<!-- ABOUT THE PROJECT --> | ||
## About The Project | ||
|
||
data:image/s3,"s3://crabby-images/813ca/813caa1bea9085188ea047b3331ac4f17a837a33" alt="" | ||
|
||
Hyprnotify is a [Freedesktop.org](https://specifications.freedesktop.org/notification-spec/notification-spec-latest.html) compliant notification daemon implementing `hyprctl notify` as its backend. | ||
|
||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
<!-- GETTING STARTED --> | ||
## Getting Started | ||
|
||
To get hyprnotify you can either download the binary build by github actions. Or build it locally. | ||
|
||
### Prerequisites | ||
|
||
- `go` compiler | ||
- `libnotify` to send notifications with `notify-send` (optional) | ||
|
||
### Compiling | ||
|
||
1. Clone the repo and cd into it | ||
```sh | ||
git clone https://github.com/codelif/hyprnotify.git | ||
cd hyprnotify | ||
``` | ||
2. Build | ||
```sh | ||
go build ./cmd/hyprnotify | ||
``` | ||
3. Run the binary | ||
```sh | ||
./hyprnotify | ||
``` | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- USAGE EXAMPLES --> | ||
## Usage | ||
Execute the daemon: | ||
```sh | ||
./hyprnotify | ||
``` | ||
Now execute any of the command in another shell:\ | ||
|
||
Send a notification: | ||
```sh | ||
notify-send "Hello, World!" | ||
``` | ||
Add a font-size hint: | ||
```sh | ||
notify-send "This is very big!" -h string:x-hyprnotify-font-size:40 | ||
``` | ||
Add a urgency hint and last for 20 seconds: | ||
```sh | ||
notify-send "This is serious stuff!" -u critical -t 20000 | ||
``` | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- ROADMAP --> | ||
## Roadmap | ||
|
||
- [x] Implement the DBus Specification | ||
- [x] Replace shell command invocation with IPC | ||
- [ ] Hints Support: | ||
- [x] urgency | ||
- [x] font-size | ||
- [ ] color | ||
- [ ] Add support for sound | ||
- [ ] Fix race condition in `CloseNotification` Signal | ||
- [ ] Scrap the Project | ||
|
||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- CONTRIBUTING --> | ||
## Contributing | ||
|
||
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**. | ||
|
||
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". | ||
Don't forget to give the project a star! Thanks again! | ||
|
||
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 | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- LICENSE --> | ||
## License | ||
|
||
Distributed under the Apache-2.0 License. See `LICENSE` for more information. | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- CONTACT --> | ||
## Contact | ||
|
||
Harsh Sharma - [@codelif_](https://x.com/codelif_) - goharsh007@google.com | ||
|
||
Project Link: [https://github.com/codelif/hyprnotify](https://github.com/codelif/hyprnotify) | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- ACKNOWLEDGMENTS --> | ||
## Acknowledgments | ||
|
||
* [hyprwm community](https://github.com/hyprwm/Hyprland) for Hyprland (special thanks to [vaxry](https://github.com/vaxerski)) | ||
* [go](https://go.dev) for go | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
|
||
|
||
<!-- MARKDOWN LINKS & IMAGES --> | ||
<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links --> | ||
[contributors-shield]: https://img.shields.io/github/contributors/codelif/hyprnotify.svg?style=for-the-badge | ||
[contributors-url]: https://github.com/codelif/hyprnotify/graphs/contributors | ||
[forks-shield]: https://img.shields.io/github/forks/codelif/hyprnotify.svg?style=for-the-badge | ||
[forks-url]: https://github.com/codelif/hyprnotify/network/members | ||
[stars-shield]: https://img.shields.io/github/stars/codelif/hyprnotify.svg?style=for-the-badge | ||
[stars-url]: https://github.com/codelif/hyprnotify/stargazers | ||
[issues-shield]: https://img.shields.io/github/issues/codelif/hyprnotify.svg?style=for-the-badge | ||
[issues-url]: https://github.com/codelif/hyprnotify/issues | ||
[license-shield]: https://img.shields.io/github/license/codelif/hyprnotify.svg?style=for-the-badge | ||
[license-url]: https://github.com/codelif/hyprnotify/blob/master/LICENSE.txt | ||
[product-screenshot]: images/screenshot.png | ||
[golang-shield]: https://img.shields.io/badge/Golang-00ADD8?style=for-the-badge&logo=go&logoColor=FFFFFF | ||
[golang-url]: https://go.dev |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.