Advanced Tasks

You can do a lot through Manyfold’s UI, but because we’re still building the app, there are some things that are difficult or time-consuming to do. This page lists some useful tasks that you can perform via a command-line interface instead.

These commands are for advanced use only and are somewhat risky. You can easily break your system or lose data if you get them wrong. Be careful!

Rails Console Commands

All the commands below are run in the Rails console. To open the console, run something like this on the machine hosting your Manyfold server, substituting the appropriate paths and container names for your system:

docker exec -it manyfold /usr/src/app/bin/rails console

You should get an irb prompt, and then you’re ready.

Remove all tags

Sometimes scanning an existing library can produce a load of tags you don’t want, or just far too many. To remove all tags:

ActsAsTaggableOn::Tagging.delete_all
ActsAsTaggableOn::Tag.delete_all

Rescan all models

If parsing metadata from path during scan didn’t work as you intended, you might want to force a full rescan to try it again. First, you’ll want to remove all tags, otherwise metadata won’t be populated; then, run:

Model.find_each { |m| Scan::CheckModelJob.perform_later(m.id, scan: true) }

This might take a while to run if you have a lot of models. The scans will run in the background once queued up.

Remove all missing files

If you have a file clearout (for instance, deleting a load of pre-sliced files), you might end up with a lot of “missing files” problems in Manyfold after a rescan. Removing these all one by one can be difficult, so you can remove them all in one command by running:

Problem.where(problematic_type: "ModelFile", category: :missing).each {|x| x.problematic.destroy}

Debugging invalid files

Due to the occasional bug, it’s possible that a file (or other) record might get in a bad state. To print out details of any with errors, run:

ModelFile.find_each { |x| puts "#{x.model.name} / #{x.name}" if !x.valid? }

Test email settings

When setting up an instance for the first time, it can be helpful to test the email settings and adjust as necessary. We can test with the account approved message to the first user account created on the server (id: 1). The rails console will report any errors encountered.

UserMailer.with(user: User.find(1)).account_approved.deliver_now