Theatre

The Theatre is a totally self contained runtime that runs all your skills. It also handles operations that span multiple skills, like boot or upgrade.

In a technical sense, it’s a monorepo that contains all your skills that uses pm2 to runs each skill. It relies on a bunch of bash scripts to do a lot of the heavy lifting.

The Sprucebot Theatre you downloaded as part of the onboarding is an Electron app that points to the local Theatre installed at ~/.spruce/theatre-monorepo.

When you open the Sprucebot Theatre app, it actually executes the following commands behind-the-scenes:

cd ~/.spruce/theatre-monorepo 
yarn boot

And when you shutdown the app, it runs:

cd ~/.spruce/theatre-monorepo
yarn shutdown

Theatre Commands

Note: If you are working with the Theatre directly, you use yarn to execute scripts. The SpruceCLI is used when working with individual Skills.

If you are working directly with the Theatre in your favorite terminal app, you have the following commands available:

CommandDescription
yarn setup.theatre <path/to/blueprint.yml>Sets up the Theatre with the given blueprint.yml. It’ll git clone all the skills defined in the blueprint.yml and then copy in any settings based on namespace
yarn boot [namespace]If no namespace is supplied, it boots the Theatre by running yarn boot on all skills. If a namespace is supplied, it runs just on that Skill.
yarn reboot [namespace]Runs yarn shutdown, resets boot counts, and then runs yarn boot on all skills. If a namespace is supplied, it will run those commands on just that Skill.
yarn run update [namespace]Runs git pull on each skill, then runs yarn at the root level to ensure the latest dependencies are installed. If a namespace is supplied, it’ll only git pull for that Skill.
yarn run upgrade [namespace]Runs git pull and then spruce upgrade on each skill. If a namespace is supplied, it’ll only run on that skill.
yarn shutdown [namespace]Shuts down all skills unless an namespace is supplied. In that case, it’ll only kill the Skill you specify.
yarn commit.push.skills <commit message>Runs git commit -m <message> and then git push on every skill.
yarn repairIf you ever run into any pm2 issues where it can’t find yarn, this will fix that issue. Make sure you yarn shutdown before running this!
yarn monitorStarts the pm2 monitor. Which is a good way of seeing the live status of each of your skills
yarn logs <namespace> [--lines=N]Tails the logs of the specified skill with an option for how many lines of logs you want to see.
yarn rebuildRebuilds the Theatre and all skills by clearing out all node_modules and all build directories and starting over.
yarn list.runningLists all status of all skills, including online/stopped, restart count, cpu usage, and memory usage.

Blueprint.yml

Here is an example of a blueprint.yml file that you may edit to suit your needs:

skills:
  - git@github.com:sprucelabsai-community/spruce-adventure-skill.git
  - git@github.com:sprucelabsai-community/spruce-eightbitstories-skill.git
  - git@github.com:sprucelabsai/spruce-appointments-skill.git
  - git@github.com:sprucelabsai/spruce-calendar-skill.git
  - git@github.com:sprucelabsai/spruce-demo-skill.git
  - git@github.com:sprucelabsai/spruce-developer-skill.git
  - git@github.com:sprucelabsai/spruce-esm-skill.git
  - git@github.com:sprucelabsai/spruce-feed-skill.git
  - git@github.com:sprucelabsai/spruce-feedback-skill.git
  - git@github.com:sprucelabsai/spruce-files-skill.git
  - git@github.com:sprucelabsai/spruce-forms-skill.git
  - git@github.com:sprucelabsai/spruce-groups-skill.git
  - git@github.com:sprucelabsai/spruce-heartwood-skill.git
  - git@github.com:sprucelabsai/spruce-help-skill.git
  - git@github.com:sprucelabsai/spruce-images-skill.git
  - git@github.com:sprucelabsai/spruce-invites-skill.git
  - git@github.com:sprucelabsai/spruce-lbb-skill.git
  - git@github.com:sprucelabsai/spruce-locations-skill.git
  - git@github.com:sprucelabsai/spruce-madrix-skill.git
  - git@github.com:sprucelabsai/spruce-mercury-api.git
  - git@github.com:sprucelabsai/spruce-organization-skill.git
  - git@github.com:sprucelabsai/spruce-people-skill.git
  - git@github.com:sprucelabsai/spruce-permissions-skill.git
  - git@github.com:sprucelabsai/spruce-profile-skill.git
  - git@github.com:sprucelabsai/spruce-reminders-skill.git
  - git@github.com:sprucelabsai/spruce-roles-skill.git
  - git@github.com:sprucelabsai/spruce-shifts-skill.git
  - git@github.com:sprucelabsai/spruce-skills-skill.git
  - git@github.com:sprucelabsai/spruce-theatre-skill.git
  - git@github.com:sprucelabsai/spruce-theme-skill.git
  - git@github.com:sprucelabsai/spruce-waivers-skill.git
  - git@github.com:sprucelabsai/spruce-wifi-skill.git
  - git@github.com:sprucelabsai/spruce-xa-skill.git
  - git@github.com:sprucelabsai/spruce-crud-views-skill.git

admin:
  - phone: "********"

env:
  universal:
    - DB_NAME: ""
    - DB_CONNECTION_STRING: "mongodb://localhost:27017"
    - MAXIMUM_LOG_PREFIXES_LENGTH: 1
    - HOST: "http://127.0.0.1:8081"
  mercury:
    - PORT: "8081"
    - ANONYMOUS_PERSON_PHONE: "555-000-0001"
    - DEMO_NUMBERS: "*"
    - ADMIN_NUMBERS: ""
    - SHOULD_ENABLE_LLM: "false"
  heartwood:
    - ANIMATION_DURATION: "500"
    - WEB_SERVER_PORT: 8080
  madrix:
    - MADRIX_ENDPOINT: "http://10.106.6.181:8082"
  eightbitstories:
    - OPENAI_API_KEY: "********"


Once you get a blueprint.yml how you like it, you can run:

yarn setup.theatre path/to/blueprint.yml

Which will leave you with a fully setup Theatre with all your skills ready to go!

It looks like you are using Internet Explorer. While the basic content is available, this is no longer a supported browser by the manufacturer, and no attention is being given to having IE work well here.