{"id":49547729,"url":"https://github.com/lyraphase/lyraphase_workstation","last_synced_at":"2026-05-02T20:08:33.182Z","repository":{"id":11157683,"uuid":"13528791","full_name":"LyraPhase/lyraphase_workstation","owner":"LyraPhase","description":"lyraphase_workstation cookbook","archived":false,"fork":false,"pushed_at":"2025-03-14T09:24:42.000Z","size":1056,"stargazers_count":10,"open_issues_count":8,"forks_count":4,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-07-14T15:13:52.902Z","etag":null,"topics":["ableton","chef","cookbook","daw","development","hacktoberfest","homebrew","lyraphase","macos","maxmsp","music-production","osx","provisioning","ruby"],"latest_commit_sha":null,"homepage":"","language":"Ruby","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/LyraPhase.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":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null},"funding":{"github":["trinitronx"],"patreon":"phasik","ko_fi":"trinitronx","liberapay":"trinitronx","custom":["https://paypal.me/JamesCuzella"]}},"created_at":"2013-10-12T20:49:09.000Z","updated_at":"2025-05-20T12:35:25.000Z","dependencies_parsed_at":"2024-11-23T04:03:24.640Z","dependency_job_id":null,"html_url":"https://github.com/LyraPhase/lyraphase_workstation","commit_stats":null,"previous_names":[],"tags_count":83,"template":false,"template_full_name":null,"purl":"pkg:github/LyraPhase/lyraphase_workstation","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LyraPhase%2Flyraphase_workstation","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LyraPhase%2Flyraphase_workstation/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LyraPhase%2Flyraphase_workstation/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LyraPhase%2Flyraphase_workstation/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/LyraPhase","download_url":"https://codeload.github.com/LyraPhase/lyraphase_workstation/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LyraPhase%2Flyraphase_workstation/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32547709,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-02T19:18:06.202Z","status":"ssl_error","status_checked_at":"2026-05-02T19:16:21.335Z","response_time":132,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5: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":["ableton","chef","cookbook","daw","development","hacktoberfest","homebrew","lyraphase","macos","maxmsp","music-production","osx","provisioning","ruby"],"created_at":"2026-05-02T20:08:31.638Z","updated_at":"2026-05-02T20:08:33.175Z","avatar_url":"https://github.com/LyraPhase.png","language":"Ruby","funding_links":["https://github.com/sponsors/trinitronx","https://patreon.com/phasik","https://ko-fi.com/trinitronx","https://liberapay.com/trinitronx","https://paypal.me/JamesCuzella","https://liberapay.com/trinitronx/donate"],"categories":[],"sub_categories":[],"readme":"\u003c!-- markdownlint-configure-file\n{\n  \"required-headings\": {\n    \"headings\": [\n      \"# lyraphase_workstation cookbook\",\n      \"*\",\n      \"# Requirements\",\n      \"*\",\n      \"# Usage\",\n      \"*\",\n      \"## Sponsor\",\n      \"*\",\n      \"## Migration\",\n      \"*\",\n      \"# Attributes\",\n      \"*\",\n      \"# Recipes\",\n      \"*\",\n      \"# Author\",\n      \"*\"\n    ]\n  }\n}\n--\u003e\n\n# lyraphase_workstation cookbook\n\n[![ci](https://github.com/LyraPhase/lyraphase_workstation/actions/workflows/ci.yml/badge.svg)](https://github.com/LyraPhase/lyraphase_workstation/actions/workflows/ci.yml)\n[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit\u0026logoColor=white)](https://github.com/pre-commit/pre-commit)\n[![pre-commit](https://github.com/LyraPhase/lyraphase_workstation/actions/workflows/pre-commit.yml/badge.svg)](https://github.com/LyraPhase/lyraphase_workstation/actions/workflows/pre-commit.yml)\n\nA cookbook including various recipes for installing tools used by myself.\nThis includes Ableton Live [DAW][1], VSTs, and other various tools and\nutilities.\n\n# Requirements\n\n- Mac OS X\n\n# Usage\n\nInclude the recipes you want in your Chef `run_list`, or in your\n[`soloistrc` file][sprout-wrap].\n\n**NOTE:** The default URLs for non-free applications **_may_ not work for you**.\nYou may want to host your own `.dmg` and app install files.  Please see the\nrecipe's cooresponding `attributes` file for examples.  All checksums are\nSHA256, and can be found via `shasum -a 256 path/to/file/here.dmg`.\n\nYou may decide to create a DAW Chef Role such as:\n\n`roles/osx-daw.json`:\n\n    {\n      \"json_class\": \"Chef::Role\",\n      \"name\": \"osx-daw\",\n      \"description\": \"Role for configuring OSX as a Digital Audio Workstation\",\n      \"override_attributes\": {\n        \"homebrew\": {\n          \"casks\": [\n            \"keyfinder\",\n            \"soundflower\",\n            \"audacity\"\n          ]\n        },\n        \"lyraphase_workstation\": {\n          \"ableton_live\": {\n            \"managed_versions\": \"all\",\n            \"options\": [\"EnableMapToSiblings\"],\n            \"dmg\": {\n              \"source\": \"http://www.example.com/mac/dmgs/ableton_live_suite_10.0.1_64.dmg\",\n              \"checksum\": \"73f8b7d9c2e058639466cbb765e6e1610f97f542745e2c69567d7bf55a407e11\",\n              \"volumes_dir\": \"Ableton Live 10 Suite Installer\",\n              \"dmg_name\": \"ableton_live_suite_10.0.1_64\",\n              \"app\": \"Ableton Live 10 Suite\"\n            }\n          }\n        }\n      },\n      \"run_list\": [\n        \"recipe[lyraphase_workstation::airfoil]\",\n        \"recipe[lyraphase_workstation::ableton_live]\",\n        \"recipe[lyraphase_workstation::ableton_live_options]\",\n        \"recipe[lyraphase_workstation::max_for_live]\",\n        \"recipe[lyraphase_workstation::traktor]\",\n        \"recipe[lyraphase_workstation::traktor_audio_2]\",\n        \"recipe[lyraphase_workstation::dmgaudio_dualism]\",\n        \"recipe[lyraphase_workstation::oxium]\",\n        \"recipe[lyraphase_workstation::polyverse_infected_mushroom_i_wish]\",\n        \"recipe[lyraphase_workstation::mixed_in_key]\",\n        \"recipe[lyraphase_workstation::korg_kontrol_editor]\",\n        \"recipe[lyraphase_workstation::sublime_text_settings]\",\n        \"recipe[lyraphase_workstation::nfs_mounts]\",\n        \"recipe[lyraphase_workstation::bash_it_custom_plugins]\",\n        \"recipe[lyraphase_workstation::daisydisk]\",\n        \"recipe[lyraphase_workstation::drobo_dashboard]\",\n        \"recipe[lyraphase_workstation::prolific_pl2303_driver]\"\n      ]\n    }\n\nThere are also some non-DAW related recipes included in this cookbook.\n\nYou may also decide to create a development tool Chef Role such as:\n\n`roles/osx-development.json`:\n\n    {\n      \"json_class\": \"Chef::Role\",\n      \"name\": \"osx-development\",\n      \"description\": \"Role for configuring OSX with developer tools\",\n      \"override_attributes\": {\n        \"lyraphase_workstation\": {\n          \"nfs_mounts\": [\n            \"/../Volumes/my-nfs-mount    -fstype=nfs,nolockd,resvport,hard,bg,intr,rw,tcp,nfc nfs://nfs-server.example.com:/export/my-nfs-mount\"\n          ]\n        }\n      },\n      \"run_list\": [\n        \"recipe[sublime_text_settings]\",\n        \"recipe[nfs_mounts]\",\n        \"recipe[homebrew_sudoers]\",\n        \"recipe[iterm2_shell_integration]\",\n        \"recipe[bash4]\",\n        \"recipe[bash_it_custom_plugins]\",\n        \"recipe[gpg21]\"\n      ]\n    }\n\nTo use the `sublime_text_settings` recipe, place your Sublime Text 3\nApplication Data folders under\n\n    \"#{node['lyraphase_workstation']['home']}/pCloud Drive/AppData/mac/sublime-text-3/\"\n\nThe recipe will create [Symbolic Links][symlink] to these files in the usual\nlocation:\n\n    \"#{node['lyraphase_workstation']['home']}/Library/Application Support/Sublime Text 3/\"\n\nThe result is that your Sublime Text 3 folders get synced to pCloud, and Sublime\nText can look for them in the default location, follow the symlink to the pCloud\ndestination files.\n\nThe `nfs_mounts` recipe will just mount things in the list of `nfs_mounts`\nfor you.  The `/../` part in front of `/../Volumes/` happens to be important!\nThe reason is because the OSX `/etc/auto_nfs` file does not usually want to mount\nthings under `/Volumes`.  Putting the `/../` in front allows you to use\nautomount to mount NFS volumes there.\n\nThe `homebrew_sudoers` recipe uses the included\n`templates/default/sudoers.d/homebrew_chef.erb` template to fix `sudo`\npermissions when running `chef-client` or `soloist` to provision your OSX\nmachine.  Without this, you may be asked for `sudo` password far too many times\nthan is feasible to type.  The included `sudoers.d` file drop-in allows the\n[`homebrew` cookbook][homebrew-cookbook] to run the\n[commands it needs][homebrew-sudo-bug] via passwordless `sudo`.\n\nThe `iterm2_shell_integration` recipe installs iTerm via `iterm` recipe, and\nthen [iTerm2 Shell Integration][iterm2-shell] via script url\n`https://iterm2.com/misc/install_shell_integration.sh`. Checksum may not be kept\nup to date, but you can change this.\nSee the recipe's attributes (`attributes/iterm2_shell_integration.rb`).\n\nThe `iterm` recipe installs iTerm via [Homebrew](https://brew.sh). It then\ninstalls my default preferences file via template\n`templates/default/com.googlecode.iterm2.plist.erb`.  You may not want this and\nmay want to use a wrapper cookbook that just calls `include_recipe 'iterm'` so\nyou can override my template.\n\nThe `bash4` recipe installs Bash version 4 via Homebrew and changes your login\nshell. It also configures `/etc/shells` with a list of shells from attribute\n`node['lyraphase_workstation']['bash']['etc_shells']`. If you do not want to\nreset your login shell to bash from Homebrew, set\n`default['lyraphase_workstation']['bash']['set_login_shell'] = false`.\nThe `etc_shells_path` is also configurable (see `attributes/bash4.rb`).\n\nThe `bash_it_custom_plugins` recipe uses `sprout-base::bash_it` to install a\nlist of plugins for [Bash-it][bash-it].  The default list is in\n`node.default['lyraphase_workstation']['bash_it']['custom_plugins']`.\nSee the [`sprout-base` cookbook][sprout-base] for more details.\n\nThe `gpg21` recipe installs GnuPG version 2.1 via `homebrew/versions` Homebrew\nTap. It ensures that old symlinks to gpg binaries are deleted (configurable via\n`node['lyraphase_workstation']['gpg21']['binary_paths']`).  Only symlinks are\nunlinked, no old binaries should be harmed.  The recipe also installs a helper\nscript to `/usr/local/bin/fixGpgHome`, and a `LaunchAgents` to\n`/Library/LaunchAgents/com.lyraphase.gpg21.fix.plist`.  Finally, it sets\n`RunAtLoad: false` for the original\n`/Library/LaunchAgents/org.gpgtools.macgpg2.fix.plist` file.  The reason for\nthis set of patches is because the original LaunchAgent has hardcoded references\nto the old GnuPG binaries, and you may end up getting confused as to which\nversion of GPG you are really using from `gpg-agent`, `gpg`, and `gpg2`.  This\nrecipe sets them all to the new `gpg21` binaries from Homebrew.  Finally, it\nadds `StreamLocalBindUnlink yes` to your `/etc/ssh/sshd_config` so you may use\n`gpg-agent` forwarding over SSH.\n\n## Sponsor\n\nIf you find this project useful and appreciate my work,\nwould you be willing to click one of the buttons below to Sponsor this project\nand help me continue?\n\n\u003c!-- markdownlint-disable MD013  --\u003e\n| Method   | Button                                                                                                                 |\n| :------- | :--------------------------------------------------------------------------------------------------------------------: |\n| GitHub   | [💖 Sponsor](https://github.com/sponsors/trinitronx)                                                                   |\n| Liberapay| [![Donate using Liberapay](https://liberapay.com/assets/widgets/donate.svg)](https://liberapay.com/trinitronx/donate)  |\n| PayPal   | [![Donate with PayPal](https://www.paypalobjects.com/en_US/i/btn/btn_donateCC_LG.gif)](https://paypal.me/JamesCuzella) |\n| Ko-Fi    | [![Donate with Ko-Fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/trinitronx)                        |\n\u003c!-- markdownlint-enable MD013  --\u003e\n\nEvery little bit is appreciated! Thank you! 🙏\n\n## Migration\n\n**Note:** This Chef Cookbook has migrated from the old location\n(`trinitronx/lyraphase_workstation`) to `LyraPhase/lyraphase_workstation`.\nIt has **NOT** changed ownership or maintainers at this time. It has been moved\nto benefit from GitHub's CI/CD automation features that are available to a\nGitHub Organization.\n\nWhile all links to the previous repository location are automatically redirected\nto the new location by GitHub, it is recommended to migrate any references you\nmay have, or previously cloned `git` repos to use the new URL.\n\nTo avoid confusion, we strongly recommend updating any existing local clones to\npoint to the new repository URL.\n\n    cd path/to/trinitronx/lyraphase_workstation\n    git remote -vv  # List remote repos\n    # Find the named remote URL with 'trinitronx/lyraphase_workstation'\n    # (usually 'origin' by default)\n    # If you checked this repo out as a fork\n    # or named the remote repo something other than 'origin',\n    # then use that in the following command\n    git remote set-url origin https://github.com/LyraPhase/lyraphase_workstation.git\n    git remote -vv  # Check that the remote repo URL now contains 'LyraPhase/lyraphase_workstation'\n\nThe cookbook and recipe names have not changed. While generally repo names are\nnot as important to Chef Infra or Cinc Client, they may appear in dependency\nmanager files such as:\n\n- `Policyfile`s\n- `Berksfile`s\n- `Cheffile`s\n\nYou can do this easily in your codebase using the following commands:\n\n    grep -rin -l 'trinitronx/lyraphase_workstation' ./ | \\\n      xargs -I{} sed -i '' -e 's#trinitronx/lyraphase_workstation#LyraPhase/lyraphase_workstation#g' '{}'\n    grep -rin -l 'LyraPhase/lyraphase_workstation'  ./ | xargs -I{} git add '{}'\n    git commit -m 'Migrating Cookbook trinitronx/lyraphase_workstation =\u003e LyraPhase/lyraphase_workstation'\n\nThen, run your dependency manager tool commands appropriately.\n\n# Attributes\n\nToo many to list!  Please see the appropriate recipe's\n`attributes/\u003crecipe_here\u003e.rb` file for details.\n\nSome general rules of thumb:\n\n- `.dmg` file installers usually have the following attributes:\n  - `['lyraphase_workstation']['recipe_here']['dmg']`: A set of attributes\n    describing the DMG such as:\n    - `['source']`: A source URL for Chef to download the DMG installer from.\n      **You must set your own!** I do not intend to host these for anyone else!\n    - `['checksum']`: A SHA256 checksum of the `.dmg` file.  Get this via\n      `shasum -a 256 your-file.dmg` OR on *nix systems `sha256sum your-file.dmg`.\n    - `['volumes_dir']`: Directory name that the `.dmg` will expected to be\n      mounted under `/Volumes/`.\n    - `['dmg_name']`: Name of the `.dmg` file without the `.dmg` suffix.\n      That's it!\n    - `['app']`: Name of the `.app` folder inside the mounted `.dmg`.\n      This maps to `/Volumes/dmg_name/app_name_here.app`.\n    - `['type']`: Type of application the [dmg cookbook][dmg-cookbook] will\n      install.  This can be one of: `app`, `mkpg`, `pkg`. **Default: '`app`'**\n- `.zip` file app installations usually have these attributes:\n  - `['lyraphase_workstation']['recipe_here']['zip']`: A set of attributes\n    describing the `.zip` file:\n    - `['zip']['source']`: A source URL for Chef to download the ZIP archive\n      from.\n      **Again: You must set your own!** I do not intend to host these for\n      anyone else!\n    - `['zip']['checksum']`:  A SHA256 checksum of the `.zip` file.  Get this\n      via `shasum -a 256 your-file.zip` OR on *nix systems\n      `sha256sum your-file.zip`.\n- Some recipes have support for License Keys. To use these there are two\n  methods:\n  - `['license']` data inside Chef Attributes\n    - Just set the attributes like you normally would and the recipe will use\n      them\n  - `['license']` data inside [Encrypted Data Bags][data-bags]\n    - Check the recipe `.rb` file for the Encrypted Data Bag name, then create\n      an encrypted data bag with the same data structure as you would put under\n      `['license']`.  You may wish to use the\n      [`knife-solo_data_bag` gem][knife-solo_data_bag] to assist in operating on\n      plain files.\n      If you have a Chef Server, use the normal `knife` commands to operate on\n      the data bags.\n    - If the recipe finds an Encrypted Data Bag with `['license']` data\n      (`Hash`), it will override the Attributes and use this instead.\n\n# Recipes\n\n- `lyraphase_workstation::ableton_live`: Install [Ableton Live](https://www.ableton.com/)\n  DAW\n- `lyraphase_workstation::ableton_live_options`: Manage [Options.txt](https://help.ableton.com/hc/en-us/articles/209772865-Options-txt-file-for-Live)\n  settings for [Ableton Live](https://www.ableton.com/) DAW\n- `lyraphase_workstation::airfoil`: Install [Airfoil](https://www.rogueamoeba.com/airfoil/)\n- `lyraphase_workstation::audinate_dante_controller`: Install [Audinate Dante Controller](https://www.audinate.com/products/software/dante-controller)\n- `lyraphase_workstation::bash4`: Install [bash v4](https://github.com/Homebrew/homebrew-core/blob/master/Formula/bash.rb)\n  from Homebrew\n- `lyraphase_workstation::bash_it_custom_plugins`: Install some custom plugins\n  for [bash-it](https://github.com/Bash-it/bash-it):\n  - `git-custom_subdir_gitconfig.aliases`: Alias for `git` to support\n    [custom `.gitemail` author \u0026 email config files](https://gist.github.com/trinitronx/5979265)\n    - For example: Commit public repos as personal email \u0026 ID\n    - Commit to work repos as corporate email \u0026 ID.)\n  - `less-manpage-colors.bash`: Set `LESS_TERMCAP_*` environment variables for\n    Manpage colors in `less` Pager.\n    - Config color scheme was lifted from [Amazon Linux](https://forums.aws.amazon.com/thread.jspa?threadID=245139)\n- `lyraphase_workstation::bitfocus_companion`: Install [Bitfocus Companion](https://bitfocus.io/companion)\n- `lyraphase_workstation::cycling_74_max`: Install [CYCLING '74 MAX](https://cycling74.com/)\n- `lyraphase_workstation::daisydisk`: Install [DaisyDisk](http://www.daisydiskapp.com/)\n- `lyraphase_workstation::default`: No-Op recipe for just loading libraries this\n  cookbook provides\n- `lyraphase_workstation::dmgaudio_dualism`: Install [DMGAudio Dualism](http://www.dmgaudio.com/products_dualism.php)\n- `lyraphase_workstation::drobo_dashboard`: Install [Drobo Dashboard](http://www.drobo.com/start/)\n- `lyraphase_workstation::gpg21`: Install GnuPG 2.1 via `homebrew/versions`\n  Homebrew Tap\n  - Note that many old Homebrew Taps have been deprecated,\n    [including `homebrew/versions`](https://web.archive.org/web/20190128084759/https://github.com/Homebrew/homebrew-versions)\n  - Homebrew [`gpg-suite`](https://gpgtools.org/) recipe `version 2019.2` now\n    installs `gpg (GnuPG/MacGPG2) 2.2.17`!\n  - Therefore this recipe is only for legacy support purposes and it's\n    recommended to migrate off this version. This recipe will eventually be\n    deprecated.\n- `lyraphase_workstation::hammerspoon`: 'Install [Hammerspoon](http://www.hammerspoon.org)\n  ([GitHub](https://github.com/Hammerspoon/hammerspoon))\n- `lyraphase_workstation::hammerspoon_shiftit`: Install ShiftIt replacement: [MiroWindowManager.spoon](http://www.hammerspoon.org/Spoons/MiroWindowsManager.html)\n  ([GitHub](https://github.com/miromannino/miro-windows-manager)\n  [ShiftIt Deprecated](https://github.com/fikovnik/ShiftIt/issues/299#issuecomment-469419329))\n- `lyraphase_workstation::homebrew_sudoers`: Install\n  `/etc/sudoers.d/homebrew_chef` config settings to fix `sudo` permissions when\n  running `chef-client` or `soloist` to provision your OSX machine.\n  - Without this, you may be asked for `sudo` password far too many times than\n    is feasible to type!\n  - The included `sudoers.d` file drop-in allows the [`homebrew` cookbook][homebrew-cookbook]\n    to run the [commands it needs][homebrew-sudo-bug] via passwordless `sudo`.\n- `lyraphase_workstation::korg_kontrol_editor`: Install [Korg Kontrol Editor](http://www.korg.com/us/support/download/software/1/253/1355/)\n  ([Manual](http://www.korg.com/us/support/download/manual/1/253/1843/)\n  [Archived DL](https://web.archive.org/web/20150919212752/http://www.korg.com/filedl/61a78cbcf754384af8104114d7cde1c7/840/download.php))\n- `lyraphase_workstation::loopback_alias_ip`: Install [loopback alias IP LaunchDaemon](https://github.com/LyraPhase/lyraphase_workstation/blob/master/templates/default/com.runlevel1.lo0.alias.plist.erb)\n  for [SSH Tunneled Proxy Access to VPC / Private Network from a Docker Container][ssh-tunnel-docs]\n  - Adds support for local [SSH tunnel port forwarding across Docker bridge networks](https://gist.github.com/trinitronx/6427d6454fb3b121fc2ab5ca7ac766bc)\n  - Use case for `terraform` [explained here](https://github.com/hashicorp/terraform/issues/17754#issuecomment-383227407)\n    **Note:** GoLang `net` library must still add SOCKS5**h** support for\n    hostname DNS lookup through the tunnel!\n  - Any tool supporting `socks5h://` protocol via `HTTP_PROXY`, `HTTPS_PROXY`\n    environment variables should work fine! (e.g.: `curl`, `wget`, etc...)\n  - How to use:\n    - Install the `LaunchDaemon` with this recipe.\n    - Set up SSH `DynamicForward` tunnel using the Alias IP set in\n      `node['lyraphase_workstation']['loopback_alias_ip']['alias_ip']` attribute\n      (Default: `172.16.222.111`)\n      - **Note:** The `alias_ip` should be in a network range designated as\n        [Private Address Space by IANA](https://www.arin.net/reference/research/statistics/address_filters/)\n      - Default `alias_ip` (`172.16.222.111`) is configured to be in the\n        `172.16.0.0/12` _not_ publicly routable private IPv4 range.\n    - Run a Docker container, passing the configured Alias IP via standard\n      `*_PROXY` environment variables\n      - For example:\n\n            export PROTO='socks5h://'; export IP=172.16.222.111; export PORT=2903;\n            ssh -f -N -v -D ${IP}:${PORT} ssh-bastion-host.example.com\n            export ALL_PROXY=\"${PROTO}${IP}:${PORT}\";  HTTP_PROXY=\"$ALL_PROXY\" HTTPS_PROXY=\"$ALL_PROXY\"\n\n        - Set up Docker Networking:\n\n              docker network create -d bridge --subnet 10.1.123.0/22 --gateway 10.1.123.1 bridgenet\n\n        - Then pass the proxy to `docker run ...`:\n\n              --net=bridgenet -e HTTP_PROXY=HTTP_PROXY -e HTTPS_PROXY=HTTPS_PROXY -e ALL_PROXY=ALL_PROXY\n\n        - Alternatively, use a hostname inside the container's `/etc/hosts`:\n\n              --add-host proxy.local:$IP\n\n              export ALL_PROXY=socks5h://proxy.local:2903; export HTTPS_PROXY=$ALL_PROXY; export HTTP_PROXY=$ALL_PROXY;\n              curl -v http://your-service.vpc.local\n\n        - More complete docs \u0026 example [can be found here][ssh-tunnel-docs]\n- `lyraphase_workstation::machine_name`: Set MacOS machine name based on\n  `node[machine_domain]` [Local cookbook replacement for sprout-osx-settings::machine_name](https://github.com/pivotal-sprout/sprout-osx-settings/blob/master/recipes/machine_name.rb)\n- `lyraphase_workstation::max_for_live`: Install [Max for Live](https://www.ableton.com/en/live/max-for-live/)\n- `lyraphase_workstation::mixed_in_key`: Install [Mixed In Key](http://www.mixedinkey.com)\n- `lyraphase_workstation::multibit`: Install [Multibit](https://multibit.org/)\n- `lyraphase_workstation::musicbrainz_picard`: Install [MusicBrainz Picard](https://picard.musicbrainz.org/)\n- `lyraphase_workstation::nfs_mounts`: Manage /etc/auto_nfs entries for\n  [NFS Client mounts on OS X](https://coderwall.com/p/fuoa-g/automounting-nfs-share-in-os-x-into-volumes)\n- `lyraphase_workstation::omnifocus`: Install [OmniFocus](https://www.omnigroup.com/omnifocus)\n- `lyraphase_workstation::osx_autohide_dock`: Enable AutoHide OSX Dock, with\n  default `autohide-delay`.\n  - [AutoHide Delay](https://www.defaults-write.com/remove-the-dock-auto-hide-show-delay/)\n    is configurable via node attribute:\n    `node['lyraphase_workstation']['settings']['autohide_delay']`.\n  - AutoHide Enable / Disable can be controlled via:\n    `node['lyraphase_workstation']['settings']['autohide_dock']`\n- `lyraphase_workstation::osx_natural_scrolling`: Enable Natural Mouse Scrolling\n  OSX setting `com.apple.swipescrolldirection` for a more natural \u0026 intuitive\n  TouchPad scrolling direction.\n  - Enable / Disable via:\n    `node['lyraphase_workstation']['settings']['natural_scrolling']`\n  - Natural Scrolling on: Scrolling up/down behaves as if you are swiping a\n    piece of paper in the physical world\n    - fingers up = page down\n    - fingers down = page up\n  - Natural Scrolling off: Scrolling up/down is exactly the same as the\n    direction you are moving your fingers\n    - fingers up = page up\n    - fingers down = page down\n- `lyraphase_workstation::oxium`: Install [Xils-Lab Oxium](http://www.xils-lab.com/pages/Oxium.html)\n  Synthesizer\n- `lyraphase_workstation::polyverse_infected_mushroom_gatekeeper`: Install\n  [Polyverse - Infected Mushroom - Gatekeeper VST](https://polyversemusic.com/products/gatekeeper/)\n- `lyraphase_workstation::polyverse_infected_mushroom_i_wish`: Install\n  [Polyverse - Infected Mushroom - I Wish VST](https://polyversemusic.com/products/i-wish/)\n- `lyraphase_workstation::polyverse_infected_mushroom_manipulator`: Install\n  [Polyverse - Infected Mushroom - Manipulator VST](https://polyversemusic.com/products/manipulator/)\n- `lyraphase_workstation::prolific_pl2303_driver`: Install [Prolific PL2303 Driver](http://www.prolific.com.tw/US/ShowProduct.aspx?p_id=229\u0026pcid=41)\n- `lyraphase_workstation::root_bootstrap_ssh_config`: Installs a minimal\n  `.ssh/config` + `known_hosts` file for GitHub \u0026 Homebrew bootstrap\n- `lyraphase_workstation::ssh_tunnel_port_override`: Install\n  [`ssh-tunnel-port-override.sh` script](https://github.com/LyraPhase/lyraphase_workstation/blob/master/templates/default/ssh-tunnel-port-override.sh.erb)\n  \u0026 `LaunchDaemon` to allow killing some process\n  (_cough_ McAfee -Anti-virus _cough_ 🦠😷) that claims your favorite SSH tunnel\n  port (Default: `8081`) on login.\n  - Will kill the process so long as `SSH Tunnel` App has not claimed the port\n    yet.\n  - Supports CPU soft limit throttling via `SIGXCPU`, as supported by `launchd`!\n  - Logs to file: `/var/log/ssh-tunnel-override.log`\n- `lyraphase_workstation::sublime_text_settings`: Installs Settings symlinks for\n  storing [Sublime Text](http://www.sublimetext.com/) configs in pCloud Drive\n- `lyraphase_workstation::trackspacer`: Installs [WavesFactory TrackSpacer VST](https://www.wavesfactory.com/trackspacer/)\n  plugin.\n- `lyraphase_workstation::traktor`: Installs [Traktor](http://www.native-instruments.com/en/products/traktor/)\n  DJ software\n- `lyraphase_workstation::traktor_audio_2`: Installs [Traktor Audio 2 DJ](http://www.native-instruments.com/en/products/traktor/dj-audio-interfaces/traktor-audio-2/)\n  Driver\n  - **Note:** Apple deprecated `kext`/ Kernel Extension drivers in macOS\n    Catalina 10.15.\n  - Native Instruments has also officially deprecated this driver for Audio 2\n    _version 1_, which is now considered a Legacy device.\n  - The Audio 2 _version 2_ should still operate without a `kext` driver as a\n    USB class-compliant device.\n  - As such, the driver installed by this recipe may not work properly in later\n    versions of `macOS \u003e= 10.15.x`\n  - The Traktor Audio 2 version 1 is **still supported** on Linux by the [`snd-usb-caiaq`](https://www.alsa-project.org/wiki/Matrix:Module-usb-caiaq)\n    Kernel Module!\n  - Therefore, this device is a **good choice** for Linux \u0026 embedded systems\n    projects, and is known to work with Open Source drivers on Intel Edison,\n    Raspberry Pi, etc...\n  - [Mixxx has some notes about Native Instruments devices \u0026 controllers here](https://www.mixxx.org/wiki/doku.php/hardware_compatibility)\n  - This device luckily does not send NHL nor MIDI, it is just a simple\n    2 channel sound card!\n- `lyraphase_workstation::user_default_shell`: Sets a default shell for your\n  user\n- `lyraphase_workstation::vimrc`: Installs vimrc via git repo\n- `lyraphase_workstation::xcode`: Install XCode via .dmg and accepts XCode build\n  license\n\n# Author\n\nAuthor:: James Cuzella ([@trinitronx][keybase-id])\n\n[1]: https://en.wikipedia.org/wiki/Digital_audio_workstation\n[keybase-id]: https://gist.github.com/trinitronx/aee110cbdf55e67185dc44272784e694\n[sprout-wrap]: https://github.com/LyraPhase/sprout-wrap/\n[dmg-cookbook]: https://github.com/chef-cookbooks/dmg\n[data-bags]: https://docs.chef.io/data_bags.html\n[knife-solo_data_bag]: https://github.com/thbishop/knife-solo_data_bag\n[symlink]: https://en.wikipedia.org/wiki/Symbolic_link\n[homebrew-cookbook]: https://github.com/chef-cookbooks/homebrew\n[homebrew-sudo-bug]: https://github.com/chef-cookbooks/homebrew/issues/105\n[iterm2-shell]: https://www.iterm2.com/documentation-shell-integration.html\n[bash-it]: https://github.com/Bash-it/bash-it\n[sprout-base]: https://github.com/pivotal-sprout/sprout-base\n[ssh-tunnel-docs]: https://github.com/LyraPhase/lyraphase_workstation/blob/master/docs/SSH%20Tunneled%20Proxy%20Access%20to%20VPC%20from%20Docker%20Container.md\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flyraphase%2Flyraphase_workstation","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flyraphase%2Flyraphase_workstation","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flyraphase%2Flyraphase_workstation/lists"}