Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Media detection over HTTP #7

Open
erengy opened this issue Jan 30, 2022 · 0 comments
Open

Media detection over HTTP #7

erengy opened this issue Jan 30, 2022 · 0 comments

Comments

@erengy
Copy link
Owner

erengy commented Jan 30, 2022

Anisthesia currently has the following strategies for media detection:

  • open_files: Lists files opened by a media player process.
  • window_title: Reads the window title of a media player.
  • ui_automation: Reads the address bar and the tabs of a web browser.

These methods either do not work or are not reliable for some media players/servers such as Plex (erengy/taiga#115), Kodi (erengy/taiga#192), Emby (erengy/taiga#268, erengy/taiga#1007) and Jellyfin. In order to support them, we need to be able to work with HTTP APIs.

Here lies the problem. Quoting from erengy/taiga#115 (comment):

Anisthesia doesn't have the capabilities to communicate over HTTP, parse JSON/XML documents, etc. C++'s standard library doesn't come with those, embedding them into the library is a bad idea, and I'd rather avoid introducing third-party dependencies...

I see two options:

  1. Introduce dependencies to Anisthesia (e.g. hypr, json, pugixml)
  2. Offload implementation details to applications (e.g. Taiga)

Either way, adding Anisthesia to your project becomes more complicated. For the first option, you would need to compile the dependencies too. For the second option, you would be responsible for handling the HTTP requests, etc.

The first option is probably easier for me personally, since I'd just use the same libraries for both Anisthesia and Taiga. But I'm not sure which one would be the best choice overall.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant