summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2019-03-28 02:16:11 +0100
committerGitHub <noreply@github.com>2019-03-28 02:16:11 +0100
commit5d41532d94eda8da692044b7b875cf68e20dfc96 (patch)
tree382f084ef2fcd860b50d5981a13a6f52faf5b645 /lib
parent08ec7435ce10fc74c257e089d6a2e909287e3daa (diff)
Add `tootctl search deploy` to avoid ugly rake task syntax (#10403)
Diffstat (limited to 'lib')
-rw-r--r--lib/cli.rb4
-rw-r--r--lib/mastodon/search_cli.rb22
2 files changed, 26 insertions, 0 deletions
diff --git a/lib/cli.rb b/lib/cli.rb
index 59f0f30766b..65a5ae69623 100644
--- a/lib/cli.rb
+++ b/lib/cli.rb
@@ -5,6 +5,7 @@ require_relative 'mastodon/media_cli'
require_relative 'mastodon/emoji_cli'
require_relative 'mastodon/accounts_cli'
require_relative 'mastodon/feeds_cli'
+require_relative 'mastodon/search_cli'
require_relative 'mastodon/settings_cli'
require_relative 'mastodon/statuses_cli'
require_relative 'mastodon/domains_cli'
@@ -28,6 +29,9 @@ module Mastodon
desc 'feeds SUBCOMMAND ...ARGS', 'Manage feeds'
subcommand 'feeds', Mastodon::FeedsCLI
+ desc 'search SUBCOMMAND ...ARGS', 'Manage the search engine'
+ subcommand 'search', Mastodon::SearchCLI
+
desc 'settings SUBCOMMAND ...ARGS', 'Manage dynamic settings'
subcommand 'settings', Mastodon::SettingsCLI
diff --git a/lib/mastodon/search_cli.rb b/lib/mastodon/search_cli.rb
new file mode 100644
index 00000000000..42ad93f1edb
--- /dev/null
+++ b/lib/mastodon/search_cli.rb
@@ -0,0 +1,22 @@
+# frozen_string_literal: true
+
+require_relative '../../config/boot'
+require_relative '../../config/environment'
+require_relative 'cli_helper'
+
+module Mastodon
+ class SearchCLI < Thor
+ desc 'deploy', 'Create or update an ElasticSearch index and populate it'
+ long_desc <<~LONG_DESC
+ If ElasticSearch is empty, this command will create the necessary indices
+ and then import data from the database into those indices.
+
+ This command will also upgrade indices if the underlying schema has been
+ changed since the last run.
+ LONG_DESC
+ def deploy
+ processed = Chewy::RakeHelper.upgrade
+ Chewy::RakeHelper.sync(except: processed)
+ end
+ end
+end