Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/techgaun/ex_mustang
:sparkles: A simple, clueless bot
https://github.com/techgaun/ex_mustang
bot elixir hacktoberfest responder slack slack-bot standup-reminder uptime-check uptime-monitoring
Last synced: 2 months ago
JSON representation
:sparkles: A simple, clueless bot
- Host: GitHub
- URL: https://github.com/techgaun/ex_mustang
- Owner: techgaun
- License: apache-2.0
- Created: 2016-08-16T01:03:41.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-10-08T05:23:42.000Z (over 4 years ago)
- Last Synced: 2024-04-14T06:05:25.287Z (9 months ago)
- Topics: bot, elixir, hacktoberfest, responder, slack, slack-bot, standup-reminder, uptime-check, uptime-monitoring
- Language: Elixir
- Homepage:
- Size: 569 KB
- Stars: 70
- Watchers: 6
- Forks: 9
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - A simple, clueless slackbot and collection of responders. (Chatting)
- fucking-awesome-elixir - ExMustang - A simple, clueless slackbot and collection of responders. (Chatting)
- awesome-nepal - Mustang Slackbot
- awesome-elixir - ExMustang - A simple, clueless slackbot and collection of responders. (Chatting)
README
# ex_mustang
> A simple, clueless bot
![Mustang](images/mustang.jpg)
ExMustang is a bot for Slack written in Elixir. While ExMustang is written for Slack, the responder modules should work fine with other Hedwig adapters as well. If you like Mustang, please use [Mustang](images/mustang.jpg) as bot image if possible :)
_Warning: This is a work in progress._
![Example](images/example.png)
![Example](images/example2.png)
![Example](images/example3.png)
### Setup
Create a Slack bot user from [here](https://my.slack.com/services/new/bot). You will receive an API token you can use. Set the `SLACK_API_TOKEN` environment variable and you should be good to go.
You can run this bot as below:
```shell
export SLACK_API_TOKEN=""
mix run --no-halt
```A sample runner configuration looks like below:
```shell
export SLACK_API_TOKEN=" - Displays all help commands that match .
gmap - Replies with the information from google places/maps.
pwned - Checks to see if an account has been breached or not
quote - Replies with a random quote.
slap - Slaps the user. Format: slap | me
time - get time in a given timezone
unix2iso - Converts given unix timestamp to ISO format (Auto-replies for values that look like timestamps)
b64encode - base64 encoding of given text content
b64decode - base64 decoding of given text content
isitup - checks if given domain is up or not
insult me| - insults given username with random insults
httpcat - get http status code cat for given value
howdoi - tries to find solution on the given query
commitmsg - get a random commit message
clifu [search_word] - get clifu gem (gives random clifu if no keyword is passed)
whois - gives whois query for given domain
gittip [keyword] - Get a random git tip for given keyword
happy birthday - Send happy birthday message to the user mentioned
hdeploy - Deploys configured branch to the given app
inviteall [src_channel] - invite all the members of source channel
giphy [search_term] - Tries to find a GIF matching search_term (gives random gif if no search_term is provided)
```#### Heroku Deployment
For heroku deployment to work, you need to specify the following configurations:
- `HEROKU_GITHUB_TOKEN` or `GITHUB_TOKEN`
- `HEROKU_TOKEN` which is an API key you can get from [here](https://dashboard.heroku.com/account)
- mapping of apps in your config which is a tuple of heroku app name and map of repo and branchAn example config looks like below:
```elixir
config :ex_mustang, ExMustang.Responders.HerokuDeploy,
github_token: System.get_env("HEROKU_GITHUB_TOKEN") || System.get_env("GITHUB_TOKEN"),
token: System.get_env("HEROKU_TOKEN"),
apps: [
{"casa-core-stage", %{repo: "casaiq/core", branch: "master"}}
]
```#### InviteAll Responder
The invite all responder requires you to provide a token of a non-bot and non-guest slack team member because thats how the slack api works. You can get your personal tokens from [HERE](https://api.slack.com/custom-integrations/legacy-tokens)
### Changelog
The detail changelog is available [HERE](CHANGELOG.md)
### About Mustang
Mustang (pronounced like `moostang` not like the `Ford Mustang`; I don't know phonetics) is my best friend whom I had to leave back in Nepal. After surviving [April 2015 Earthquake](https://en.wikipedia.org/wiki/April_2015_Nepal_earthquake), we lived together for a while and I had to leave him back in Nepal. Below is the pic post-earthquake.
![Mustang and Me](images/me_mustang.jpg)