Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mgleon08/slack_neuralyzer
Ruby gem for clean up messages and files on Slack.
https://github.com/mgleon08/slack_neuralyzer
cleaner ruby rubygems slack
Last synced: 2 months ago
JSON representation
Ruby gem for clean up messages and files on Slack.
- Host: GitHub
- URL: https://github.com/mgleon08/slack_neuralyzer
- Owner: mgleon08
- License: mit
- Created: 2016-10-17T13:47:56.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-09-09T03:42:48.000Z (over 7 years ago)
- Last Synced: 2024-09-22T16:16:37.729Z (4 months ago)
- Topics: cleaner, ruby, rubygems, slack
- Language: Ruby
- Size: 6.65 MB
- Stars: 57
- Watchers: 5
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Slack Neuralyzer
[![Gem Version](https://badge.fury.io/rb/slack_neuralyzer.svg)](https://badge.fury.io/rb/slack_neuralyzer)
[![Build Status](https://travis-ci.org/mgleon08/slack_neuralyzer.svg?branch=master)](https://travis-ci.org/mgleon08/slack_neuralyzer)
[![Coverage Status](https://coveralls.io/repos/github/mgleon08/slack_neuralyzer/badge.svg?branch=master)](https://coveralls.io/github/mgleon08/slack_neuralyzer?branch=master)
[![Code Climate](https://codeclimate.com/github/mgleon08/slack_neuralyzer/badges/gpa.svg)](https://codeclimate.com/github/mgleon08/slack_neuralyzer)
[![security](https://hakiri.io/github/mgleon08/slack_neuralyzer/master.svg)](https://hakiri.io/github/mgleon08/slack_neuralyzer/master)
[![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/mgleon08/slack_neuralyzer/blob/master/LICENSE.txt)Slack Neuralyzer is a ruby gem for bulk delete messages and files on Slack channels.
The easiest way to clean up messages and files on Slack.
![](https://media.giphy.com/media/65NO1TrKrJUT6/giphy.gif)
## Installation
```
$ gem install slack_neuralyzer
```## Slack token
## Getting Started
![](screenshots/slack_neuralyzer_demo.gif)
### Show all channel names
`slack_neuralyzer -t -s`
```ruby
All user direct:
001. leon
002. slackbot
003. cleanerbotAll channels (public):
001. general
002. randomAll groups (private):
001. private_channelAll multiparty direct:
001. mpdm-leon--cleanerbot-1
002. mpdm-leon--slackbot-1
```### Delete message(s)
>Rerun below command and use `-e | --execute` to actually delete the message(s).
* Channel
`-C | --channel` `-D | --direct` `-G | --group` `-M | --mpdirect`
```ruby
# Delete all user messages in general channel
slack_neuralyzer -t -m -C general -u all# Delete all user messages in leon direct channel
slack_neuralyzer -t -m -D leon -u all# Delete all user messages in private_channel groups channel
slack_neuralyzer -t -m -G private_channel -u all# Delete all user messages in mpdm-leon--cleanerbot-1 multiparty direct channel
# (can `use slack_neuralyzer -t -s` to see mpdirect channle name)
slack_neuralyzer -t -m -M mpdm-leon--cleanerbot-1 -u all
```* Specific user
`-u | --user`
```ruby
# Delete leon messages in general channel
slack_neuralyzer -t -m -C general -u leon# if you want to specific all users, you can type 'all'
slack_neuralyzer -t -m -C general -u all
```* Specific Bot
`-b | --bot`
```ruby
# Delete bots messages in general channel
slack_neuralyzer -t -m -C general -b cleanerbot# if you want to specific all bots, you can type 'all' (not bot users)
slack_neuralyzer -t -m -C general -b all
```* Delete message(s) between two dates
`-A | --after` `-B | --before`
```ruby
# Delete all user messages in general channel at 20160101 to 20161212
slack_neuralyzer -t -m -C general -u all -A 20160101 -B 20161212
```* Delete message(s) with specified text
`-R | --regex`
```ruby
# Delete all user messages with hello string in general channel
slack_neuralyzer -t -m -C general -u all -R hello
```### Delete file(s)
> File types: all, spaces, snippets, images, gdocs, docs, zips, pdfs
>Rerun below command and use `-e | --execute` to actually delete the message(s).
* Channel
`-C | --channel` `-D | --direct` `-G | --group` `-M | --mpdirect`
```ruby
# Delete all user upload all type file in general channel
slack_neuralyzer -t -f all -C general -u all# Delete leon upload all images file in leon direct channel
slack_neuralyzer -t -f images -D leon -u leon# Delete all user upload all pdfs file in private_channel groups channel
slack_neuralyzer -t -f pdfs -G private_channel -u all# Delete all user upload all zips file in mpdm-leon--cleanerbot-1 multiparty direct channel
# (can `use slack_neuralyzer -t -s` to see mpdirect channle name)
slack_neuralyzer -t -f zips -M mpdm-leon--cleanerbot-1 -u all
```* Specific user and file type
`-u | --user` `-f | --file`
```ruby
# Delete leon upload images file in general channel
slack_neuralyzer -t -f images -C general -u leon
```* Delete file between two dates
`-A | --after` `-B | --before`
```ruby
# Delete all user upload all type file in general channel at 20160101 to 20161212
slack_neuralyzer -t -f all -C general -u all -A 20160101 -B 20161212
```### Generate log file
`-l | --log`
```ruby
# Generate a log file in the current directory in ./slack_neuralyzer/YYYY-MM-DDTHH:MM:SS
slack_neuralyzer -t -m -C general -u all -A 20160101 -B 20161212 -l
```### Rate
`-r | --rate`
```ruby
# Delay between API calls in seconds (default:0.05)
slack_neuralyzer -t -m -C general -u all -r 0.01
```### Help
`-h | --help`
```
usage:
slack_neuralyzer [options]
See https://github.com/mgleon08/slack_neuralyzer for more information.options:
-t, --token TOKEN Slack API token (https://api.slack.com/web)
-s, --show Show all users, channels, groups and multiparty direct names
-m, --message Specifies that the delete object is messages
-f, --file TYPE Specifies that the delete object is files of a certain type (Type: all, spaces, snippets, images, gdocs, docs, zips, pdfs)
-C, --channel CHANNEL Public channel name (e.g., general, random)
-D, --direct DIRECT Direct messages channel name (e.g., leon)
-G, --group GROUP Private groups channel name
-M, --mpdirect MPDIRECT Multiparty direct messages channel name (e.g., mpdm-leon--bot-1 [--show option to see name])
-u, --user USER Delete messages/files from the specific user (if you want to specific all users, you can type 'all')
-b, --bot BOT Delete messages from the specific bot (not bot users, if you want to specific all bots, you can type 'all')
-A, --after DATE Delete messages/files after than this time (YYYYMMDD)
-B, --before DATE Delete messages/files before than this time (YYYYMMDD)
-R, --regex TEXT Delete messages with specified text (regular expression)
-e, --execute Execute the delete task
-l, --log Generate a log file in the current directory
-r, --rate RATE Delay between API calls in seconds (default:0.1)
-v, --version Show the SlackNeuralyzer version
-h, --help Show this message
```## Contributing
Bug reports and pull requests are welcome on GitHub at [`https://github.com/mgleon08/slack_neuralyzer/pulls`](https://github.com/mgleon08/slack_neuralyzer/pulls)
## Copyright & License
* Copyright (c) 2016 Leon Ji. See [LICENSE.txt](https://github.com/mgleon08/slack_neuralyzer/blob/master/LICENSE.txt) for further details.
* The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).