Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/towsifkafi/dbus-media-http-api
A HTTP API interfacing with the host's DBus to manage and relay media player information using the Mris MediaPlayer2 protocol.
https://github.com/towsifkafi/dbus-media-http-api
dbus golang http-api linux-desktop mpris
Last synced: 1 day ago
JSON representation
A HTTP API interfacing with the host's DBus to manage and relay media player information using the Mris MediaPlayer2 protocol.
- Host: GitHub
- URL: https://github.com/towsifkafi/dbus-media-http-api
- Owner: towsifkafi
- Created: 2024-01-28T08:21:17.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-01-28T08:21:20.000Z (12 months ago)
- Last Synced: 2024-11-18T00:43:00.301Z (2 months ago)
- Topics: dbus, golang, http-api, linux-desktop, mpris
- Language: Go
- Homepage:
- Size: 4.88 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# DBus Mris MediaPlayer HTTP API
This HTTP API connects to the host's DBus to retrieve current media information. It exposes an endpoint where this information can be accessed, and various methods can be executed.
## Endpoints
GET
/get
Returns a list of all available Mris MediaPlayer2 objects.
#### Response
```json
{
"error": false,
"result": [
{
"service": "org.mpris.MediaPlayer2.APPLICATION",
"mpris:artUrl": "BASE64 DATA",
"mpris:length": 1230,
"mpris:trackid": "TRACK ID",
"playback_status": "Playing",
"position": 1230,
"volume": 1,
"xesam:album": "",
"xesam:artist": [
"ARTIST"
],
"xesam:title": "TITLE"
}
]
}
```
GET
/{action}/{service}
Triggers a specified action in the provided service.
#### Valid actions:
* `playpause`
* `play`
* `pause`
* `stop`
* `next`
* `previous`##### Response
```json
{"error": false, "message": "ACTION executed successfully"}
```> [!NOTE]
> If you have `AUTH=true` and `AUTH_KEY=KEY` set in your .env file, you will need to add an `Authorization` header with the authentication key to your requests.## Usage
To run this HTTP API, you need a Linux machine with DBus installed. This project integrates with the DBus Mris Media Player for media player interaction. You will also need to compile this project.To compile and run this project, follow these commands:
```bash
git clone https://github.com/Towsif12/dbus-media-http-api.git
cd dbus-media-http-apigo build -o dbus-media-api ./src
chmod +x dbus-media-api./dbus-media-api
```Optionally, you can use a `.env` file to configure the port, authentication, and authentication key:
```
PORT=10004
AUTH=true
AUTH_KEY=key123
```## Development
The development process is similar to the usage instructions. Start by cloning the repository, and then you can modify the code in the `src/` directory.To run the project during development, use the following command:
```sh
go run ./src
```Feel free to submit a Pull Request (PR) or post an issue if you encounter any bugs or errors.
## Sources
These links were helpful resources throughout the development of this project:
- https://www.baeldung.com/linux/dbus
- https://github.com/godbus/dbus/
- https://github.com/joho/godotenv
- https://tutorialedge.net/golang/creating-restful-api-with-golang/
- https://specifications.freedesktop.org/mpris-spec/2.2/Player_Interface.html