{"id":41393968,"url":"https://github.com/kryops/remote-mixer","last_synced_at":"2026-01-23T12:50:06.876Z","repository":{"id":148550961,"uuid":"334415791","full_name":"kryops/remote-mixer","owner":"kryops","description":"Simple web-based interface to remote-control mixing consoles.","archived":false,"fork":false,"pushed_at":"2025-10-04T15:29:15.000Z","size":7760,"stargazers_count":16,"open_issues_count":0,"forks_count":4,"subscribers_count":3,"default_branch":"main","last_synced_at":"2025-10-04T17:31:24.761Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kryops.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.md","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2021-01-30T13:12:12.000Z","updated_at":"2025-10-04T15:29:20.000Z","dependencies_parsed_at":"2025-04-04T16:25:31.948Z","dependency_job_id":"198784b8-8d34-4a00-aa67-3175f413f8f5","html_url":"https://github.com/kryops/remote-mixer","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/kryops/remote-mixer","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kryops%2Fremote-mixer","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kryops%2Fremote-mixer/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kryops%2Fremote-mixer/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kryops%2Fremote-mixer/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kryops","download_url":"https://codeload.github.com/kryops/remote-mixer/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kryops%2Fremote-mixer/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28692035,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-23T11:01:27.039Z","status":"ssl_error","status_checked_at":"2026-01-23T11:00:26.909Z","response_time":59,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2026-01-23T12:50:06.087Z","updated_at":"2026-01-23T12:50:06.863Z","avatar_url":"https://github.com/kryops.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# remote-mixer\n\nSimple web-based interface to remote-control mixing consoles.\n\n- 🎚 Compatible with different mixers\n- 📱Responsive and mobile-friendly\n- 🚀 Lightweight and performant\n- 🕸️ Connect multiple clients\n- 🌓 Light and dark mode\n\n![Screenshot](./assets/screenshot.png)\n\n\u003e **🚧 This project is still Work in Progress! 🛠️**\n\u003e\n\u003e It should be stable enough to use at small events, but do not rely on it as your only means of mixing. **Use at your own risk**.\n\u003e\n\u003e I'm still not sure about the general direction for this project.\n\u003e Feel free to fork and experiment - PRs welcome.\n\n\u003e 💡 Also check out this project's companion app [vlight](https://github.com/kryops/vlight) for controlling DMX lights.\n\n## Features\n\nThis project is not meant to control every little functionality of a certain mixing console; usually, there are better alternatives around for that. However, many of them\n\n- only work for a single mixing console model\n- only run on a single platform like Windows or iOS\n- only support a single connected client at the same time\n- are not mobile-friendly\n\nThis project tries to bridge these limitations by supporting basic controls for different mixing consoles, accessible from any device (mouse or touch), and multiple devices at once.\n\n### Supported Mixing Consoles\n\n- [Yamaha 01v96](./backend/src/devices/yamaha-01v96/README.md)\n- [Behringer X32 / Midas M32](./backend/src/devices/behringer-x32/README.md)\n- _Add your own ([see below](#adding-support-for-other-mixing-consoles))_\n\n### Available Controls\n\n- Faders\n- On/Off buttons\n- Names\n- Meters\n- Categories (tabs), 2 levels deep\n- Colors\n\n## Getting Started\n\n### Using a Docker container (EXPERIMENTAL)\n\nYou can build and run this project through Docker (in a Linux container):\n\n```\n\u003e ./docker-build.sh\n\u003e ./docker-run.sh\n```\n\n### Normal installation\n\nSoftware needed:\n\n- [Node.js](https://nodejs.org/en/)\n- [Yarn](https://yarnpkg.com/lang/en/)\n\nBuild tools for native Node.js addons are also needed depending on your platform. If the installation fails, install the tools listed in the [node-gyp documentation](https://github.com/nodejs/node-gyp/blob/master/README.md#installation).\n\nInstall and setup:\n\n```shellscript\n\u003e yarn\n```\n\nStart in production mode:\n\n```shellscript\n\u003e yarn start\n```\n\n## Configuration\n\nEdit the `config/remote-mixer-config.js` file. Instructions on how to configure each compatible mixing console are usually contained in the corresponding README in `backend/src/devices`.\n\n```js\nconst userConfig = {\n  httpPort: 8080,\n  logLevel: 'info',\n  device: 'dummy',\n}\n\nmodule.exports = userConfig\n```\n\n## Development\n\nStart in development mode with hot reloading:\n\n```shellscript\n\u003e yarn dev\n```\n\n### Adding support for other mixing consoles\n\nCode to control different mixing consoles is located in `backend/src/devices`. Each file (or `index.ts` in a sub-directory) needs to have a `DeviceController` as default export.\n\n```ts\nimport { DeviceController, DeviceMessageListener } from '@remote-mixer/types'\n\nexport default class MyDeviceController implements DeviceController {\n  deviceConfig = {\n    categories: [\n      {\n        key: 'ch',\n        label: 'Channels',\n        count: 32,\n        meters: true,\n        namePrefix: 'CH',\n        faderProperties: [\n          { key: 'value', label: 'CH' },\n          { key: 'aux1', label: 'AUX1' },\n          // ...\n        ],\n      },\n      {\n        key: 'aux',\n        label: 'AUX',\n        count: 4,\n        namePrefix: 'AUX',\n      },\n      // ...\n    ],\n  }\n\n  constructor(private listener: DeviceMessageListener) {\n    // connect, sync, and call this.listener() for any change\n  }\n\n  change(category: string, id: string, property: string, value: string): void {\n    // send the change to the mixing console\n  }\n}\n```\n\nCheckout the [dummy device](./backend/src/devices/dummy.ts) for a minimal example that sends periodic random changes.\n\nYou can use existing device controllers as a baseline for similar consoles:\n\n- [Yamaha 01v96](./backend/src/devices/yamaha-01v96/index.ts) for a MIDI controller\n- [Behringer X32](./backend/src/devices/behringer-x32/index.ts) for an OSC controller\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkryops%2Fremote-mixer","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkryops%2Fremote-mixer","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkryops%2Fremote-mixer/lists"}