Set your Slack status via the command line
Go to file
Ian Fijolek a47d73b669
Some checks failed
continuous-integration/drone/push Build is failing
Ensure certs exist before running linting
2021-02-17 10:22:22 -08:00
.drone.yml Ensure certs exist before running linting 2021-02-17 10:22:22 -08:00
.gitignore Add embedded certificates 2021-02-17 09:43:53 -08:00
.golangci.yml Update linting 2021-02-09 10:20:38 -08:00
.pre-commit-config.yaml Add pre-commit hooks 2021-02-03 13:01:53 -08:00
auth.go Add embedded certificates 2021-02-17 09:43:53 -08:00
config.go Update linting 2021-02-09 10:20:38 -08:00
go.mod Add embedded certificates 2021-02-17 09:43:53 -08:00
go.sum Working proof of concept 2021-01-05 17:54:24 -05:00
LICENSE Initial commit 2021-01-05 22:23:21 +00:00
main.go Update linting 2021-02-09 10:20:38 -08:00
Makefile Ensure certs exist before running linting 2021-02-17 10:22:22 -08:00
README.md Update cert instructions 2021-02-03 13:01:53 -08:00
util.go Add ability to support multiple workspaces 2021-02-03 13:01:53 -08:00

slack-status-cli

Set your Slack status via the command line

Requirements

Rather than host a web server that you would need to trust, this command runs one on your local machine to retrieve the OAuth code. This page is hosted with an auto generated, self-signed certificate.

This requires you to have openssl installed on your machine and, when the page loads for the first time, it will require you to trust the certificate or ignore the warning.

Here's how to do that on Firefox. On Chrome, you may have to enable chrome://flags/#allow-insecure-localhost. If you can't get the link to open in Chrome, you can copy the URL into a different browser and try it there. It should work in Firefox or Safari.

Setup

  1. Install the command from the Releases tab

  2. Run the command! On first run, you will be asked to authenticate and install the app in your workspace

Example usage

Login (it will store it in ~/.config/slack-status-cli or your $XDG_CONFIG_HOME dir

slack-status -login
slack-status -login -domain custom-workspace-name
slack-status -make-default -domain new-default-workspace

Specify domain to use

# Use the deafult domain
slack-status :face_with_cowboy_hat: Howdy partner
# Specify domain for this status
slack-status -domain my-workspace :face_with_cowboy_hat: Howdy partner
# Specify domain for this status and make it the new default
slack-status -domain my-workspace -make-default :face_with_cowboy_hat: Howdy partner

Set status without emoji

slack-status Walking the dog

Set status with emoji

slack-status :walking-the-dog: Walking the dog
slack-status -emoji :walking-the-dog: Walking the dog

Set status with duration (eg. 10m, 2h, 7d12h)

slack-status 10m :walking-the-dog: Walking the dog
slack-status :walking-the-dog: Walking the dog for 10m
slack-status -duration 10m -emoji :walking-the-dog: Walking the dog

Set status with duration and snooze notifications

slack-status -snooze -duration 12h -emoji :bed: Good night
slack-status -snooze :bed: Good night for 12h

Set a status that contains a duration

# Set status to "On a break" for 5 minutes
slack-status :sleeping: On a break for 5m
# Set status to "On a break for 5m"  for 5 minutes
slack-status -duration 5m :sleeping: On a break for 5m
# Set status to "On a break for 5m"  with no duration
slack-status :sleeping: "On a break for 5m"

Clear existing status and snooze durations

slack-status

Snooze notifications without updating your status

slack-status -duration 15m -snooze