{"id":15116978,"url":"https://github.com/siddhpant/broo","last_synced_at":"2025-07-18T14:40:30.506Z","repository":{"id":40123731,"uuid":"427297854","full_name":"siddhpant/broo","owner":"siddhpant","description":"Connect your phone as microphone wirelessly. Supports both PipeWire and PulseAudio.","archived":false,"fork":false,"pushed_at":"2024-10-22T10:57:09.000Z","size":132,"stargazers_count":140,"open_issues_count":1,"forks_count":9,"subscribers_count":4,"default_branch":"main","last_synced_at":"2025-05-04T21:16:58.090Z","etag":null,"topics":["mic","microphone","mobile-as-mic","mobile-as-microphone","mumble","pipewire","pulseaudio","virtual-microphone","wireless-mic","wireless-microphone"],"latest_commit_sha":null,"homepage":"","language":"Shell","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"agpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/siddhpant.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","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}},"created_at":"2021-11-12T09:15:08.000Z","updated_at":"2025-04-26T07:22:11.000Z","dependencies_parsed_at":"2024-10-23T05:06:10.218Z","dependency_job_id":null,"html_url":"https://github.com/siddhpant/broo","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siddhpant%2Fbroo","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siddhpant%2Fbroo/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siddhpant%2Fbroo/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siddhpant%2Fbroo/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siddhpant","download_url":"https://codeload.github.com/siddhpant/broo/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":252399542,"owners_count":21741677,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":["mic","microphone","mobile-as-mic","mobile-as-microphone","mumble","pipewire","pulseaudio","virtual-microphone","wireless-mic","wireless-microphone"],"created_at":"2024-09-26T01:45:27.550Z","updated_at":"2025-05-04T21:17:03.616Z","avatar_url":"https://github.com/siddhpant.png","language":"Shell","funding_links":[],"categories":["Linux"],"sub_categories":["Other"],"readme":"# Broo\n \n- Connect your phone as microphone wirelessly.\n- Get clear voice and low latency with minimal CPU overhead.\n- Just run one command (`$ broo`) to quickly set-up the mic and start talking with peers.\n- Supports both modern PipeWire and legacy PulseAudio.\n- For PulseAudio use case, restores backed-up ALSA settings stored in `~/.config/asound.state`, if it exists.\n\n## Why call it Broo?\n\n- Sanskrit धातु (lexical word stem) \u0026nbsp;\" **ब्रू** \"\u0026nbsp; (brU) which means \"to speak\".\n- You go like \"BROOOOOOOOO that was NICE\" while vibing with your homies.\n\n## Requirements\n\n- A GNU/Linux distro with either PipeWire or PulseAudio.\n- A smartphone (or anything with a mic which can connect to a local Mumble server).\n    - For Android → Mumla app* ([F-Droid](https://f-droid.org/packages/se.lublin.mumla/)) [[Source](https://gitlab.com/quite/mumla)]\n    - For iOS → Official Mumble app* ([App Store](https://apps.apple.com/us/app/mumble/id443472808)) [[Source](https://github.com/mumble-voip/mumble-iphoneos)]\n\n### For distros with the `apt` package manager.\n\n- The setup script will do the heavy lifting for you. Please proceed to the installation.\n\n### Otherwise\n\nInstall the following:\n\n- `mumble`\n    - Typically includes `mumble-server` or `murmur`.\n    - If not, then install them too.\n- `avahi` or `avahi-daemon`\n- `iproute2`\n\nIf you want, you may build Mumble and its server directly from the [source](https://github.com/mumble-voip/mumble) to get improved PipeWire support, performance, and bug fixes. Compilation doesn't take much time and completes under a few minutes. Though, you may want to build a package for better uninstallation later instead of directly going the `sudo make install` route.\n\n## Installation\n\n```\n$ git clone https://github.com/siddhpant/broo.git\n$ cd broo\n$ chmod +x broo setup_broo\n$ ./setup_broo\n```\n\nThen follow the on-screen instructions.\n\n## Run\n\n```\n$ broo\nDo you want to start Broo, or close it? (s/c): \n```\n\n- Press `s` to start Broo, or `c` to stop it.\n- Use the mic by choosing `Broo` as your input source / mic in applications.\n- The script will reside in `~/.local/bin`, so you can run Broo from anywhere.\n- You can use `-h` or `--help` for help.\n\n## Audiophile?\n\nThen you can eliminate the WiFi latency by connecting your phone to your computer with a wire.\n\nUse `USB tethering` to share your smartphone's active internet connection with your computer. When Broo creates a local server, due to direct connection with the phone the WiFi latency will be bypassed, and you can observe Mumla showing 0ms latency before connecting.\n\nThis will reduce the total audio latency by a significant percentage. For example, you might reduce the latency by 15ms, but the gain can be more or less since it depends on your connection.\n\nThe network latency to the web servers of services such as Teams, Google Meet, Discord, etc. is usually higher, so in the grand scheme of things, this optimisation might not matter for the average user.\n\nFurther, this may come in handy when your WiFi adapter / card / driver is borked.\n\n## Miscellaneous\n\nIf you see that your PC's user isn't in the channel when you join from your mobile, then restart Broo and press `p` on the starting prompt of Broo. After following the on-screen steps, run Broo normally.\n\nIf the problem still persists, it would be nice to go through the setup again.\n\nYou can also force close broo with `q` and force start with `f`.\n\n---\n\n## Credits\n\nInspired by the implementation of https://github.com/pzmarzly/mic_over_mumble/.\n\nI have tried to hopefully iron out some problems with the original implementation by making the script from scratch to streamline the code, and added absolutely necessary features such as supporting PipeWire, adding prompt and ability to close the terminal, ALSA setting restore, etc.\n\n## Footnotes\n\n\\* Due to devs being busy, the iOS app is officially unmaintained, while Android app is sorta in the same boat but short of being abandoned.\n\nBut the apps seem to work for many people thanks to Mubmle's backward compatibility. **Any breakages maybe due to system changes rather than problems in Broo.**\n\nIf you are someone capable of creating apps, a new Mumble client for mobile would be a nice project. Probably could use Flutter for cross-platform (idk much), with something building on the lines of using [libmumble](https://github.com/mumble-voip/libmumble) + [dart:ffi](https://dart.dev/guides/libraries/c-interop), or [dumble](https://github.com/EPNW/dumble).\n\n---\n\n## License\n\nCopyright (C) 2021  Siddh Raman Pant\n\nThis program is free software: you can redistribute it and/or modify\nit under the terms of the GNU Affero General Public License as published\nby the Free Software Foundation, either version 3 of the License, or\n(at your option) any later version.\n\nThis program is distributed in the hope that it will be useful,\nbut WITHOUT ANY WARRANTY; without even the implied warranty of\nMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\nGNU Affero General Public License for more details.\n\nYou should have received a copy of the GNU Affero General Public License\nalong with this program.  If not, see \u003chttps://www.gnu.org/licenses/\u003e.\n\nThe online repository can be found at \u003chttps://github.com/siddhpant/broo\u003e.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsiddhpant%2Fbroo","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsiddhpant%2Fbroo","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsiddhpant%2Fbroo/lists"}