Frappe Commands

The Bench CLI utilizes the modulefrappe.utils.bench_manager to get the framework's as well as any other Application's commands present on the current bench directory.

This page is concerned only with the commands that exist in the Frappe project, that are a direct part of the CLI tool. These commands are defined under the frappe/frappe.

For references of any Bench commands, checkout Bench Commands.

There are four major command types in Frappe inherited by Bench during command executions. They can be broadly grouped into

Site Commands

Set of commands used for site-specific operations. These are the most frequented commands to alter the state of your sites. These commands are accessed by using the --site option along with the site name (or "all") if you wish to run the operation (if possible) for all sites on the bench. These commands are defined under the module

Site Creation

Create a new Site on your bench. By default, all sites created on your bench will have only the Frappe Framework installed on them.

bench new-site {site}

For more information and examples, see the bench new-site reference.

Site Backups

You can use the Bench CLI to take backups on the sites of your bench. You can manage the site's database and files backups and have more control over the operation.

bench --site {site} backup

The Bench CLI also deletes the older backup files from your bench directory. By default, it deletes backups older than 24 hours from the backups directory.

For more information and examples, see the bench backup reference.

Site Restores

Bench CLI can be used to restore an existing site to a previous state. Using the bench restore command, a site may be restored with the specific database and file restores.

bench --site {site} restore {path/to/database/file}

The least requirement for performing a restore operation is having the database file on your local filesystem. The specified backup file may have the sql.gz of sql extension.

For more information and examples, see the bench restore reference.

Site App Management

You can install or uninstall Frappe Applications available on your Bench. To add Apps to your bench using bench get-app checkout the docs.

App Installation

The easiest way to install a Frappe Application on your site is through the Bench CLI. However, the application must be installed on your bench prior to that.

bench --site {site} install-app {app}

In this operation, Application meta, modules and doctypes of the specified site are installed on the specified site.

App Uninstallation

Uninstall an app installed on site. This is a destructive action and consists of removing all app-related data from the site. Hence, a backup is taken before uninstalling said app.

bench --site {site} uninstall-app {app}

Note: From Version 13, even apps not installed on the Bench can be uninstalled from the site.

For more information and examples, see the bench uninstall-app reference.

Site Migrations

Run patches, sync schema and rebuild files, translations and indexes on a particular site.

bench --site {site} migrate

For more information and examples, see the bench migrate reference.

Site Deletion

Drops the database and moves the site directory from ./sites to the ./archived_sites (unless specified otherwise) folder on your Bench.

bench drop-site {site}

For more information and examples, see the bench drop-site reference.

Reset Site Data

Re-install all installed Applications from your specified site. This completely resets the site.

bench reinstall {site}

For more information and examples, see the bench reinstall reference.

List Installed Apps

List all the Frappe Applications installed on the specified site.

bench --site {site} list-apps

Site Operations, Debugging & Development

Here are some operations you can perform on your site via the Bench CLI to update your site state. You may never have to use some of these, but they exist just in case.

  • add-system-manager: Add a new system manager to a site.
  • add-to-hosts: Add the specified site to the hosts file on your system.
  • browse: Opens the specified site on the browser if available.
  • build-search-index: Builds search index for Websites. Refer to Full Text Search API Docs for more information.
  • disable-user: Disable user on site.
  • publish-realtime: Publish realtime event from bench.
  • reload-doc: Reload schema for a particular Doctype and refresh the specified Document
  • reload-doctype: Reload schema for a particular DocType
  • remove-from-installed-apps: Removes the mentioned app from the site gloabl value of installed_applications.
  • run-patch: Run a particular patch via the Frappe Patch Handler.
  • migrate-to: Command to migrate your local site to a Frappe Hosting Provider's service.
  • ngrok: Create a temporary URL and share it with anyone, and they can access your local site in their browser. Primarily built for aiding with the development of third party services.
  • set-admin-password: Set the password for the Administrator user.
  • set-last-active-for-user: Set users last active date to current datetime.
  • start-recording: Starts the Frappe Recorder for the specified sites.
  • stop-recording: Terminates the Frappe Recorder for the specified sites.
  • use: Sets the default site on the bench. Adds the site entry to the currentsite.txt.

Scheduler Commands

Commands to manage and review the scheduler and background jobs' statuses for the sites on your bench. Defined under module frappe.commands.schedule.

  • disable-scheduler: Disable scheduler for specified sites.
  • doctor: Get diagnostic info about the status of the scheduler for all sites (if unspecified) and active workers on bench.
  • enable-scheduler: Enables scheduler for specified sites.
  • purge-jobs: Purge any pending periodic tasks, if the event option is not given, it will purge everything for the site.
  • ready-for-migration: Checks if a particular site is ready for migration by checking the existence of any pending background jobs.
  • scheduler: Change the state of the scheduler for any site from pause, resume, disable or enable state.
  • set-maintenance-mode: Set the value for maintenance mode in the config for specified sites.
  • show-pending-jobs: Get diagnostic info about background jobs.
  • schedule: Start the scheduler process for your bench. This process manages scheduler events defined in the file. You can find this command mentioned in the bench config for your process manager too.
  • worker: Start worker process on your bench. The process this starts will manage all background jobs started on this bench.
  • trigger-scheduler-event: Trigger a specific scheduler event for the specified sites.

Frappe Utility Commands

Frappe Utility commands that can be both, site or bench specific. These commands are defined under the module frappe.commands.utils.

  • add-to-email-queue: Add an email to the Email Queue.
  • build: Builds assets for the Frappe Applications installed on bench.
  • bulk-rename: Rename multiple records via a CSV file.
  • clear-cache: Clear cache, doctype cache and defaults.
  • clear-website-cache: Clear Website cache.
  • console: Starts an IPython console for the site.
  • data-import: Import documents in bulk from CSV or XLSX using data import.
  • destroy-all-sessions: Clear sessions of all users (logs them out).
  • execute: Execute a particular function or method with a given set of args and kwargs.
  • export-csv: Export data import template with data for DocType.
  • export-doc: Export a single document to CSV.
  • export-fixtures: Export fixtures for Frappe Applications from specified site.
  • export-json: Export doclist as json to the given path, use '-' as name for Singles.
  • import-csv: Import from your CSV file using data import.
  • import-doc: Import (insert/update) doclist. If the argument is a directory, all files ending with .json are imported
  • jupyter: Starting a Jupyter Notebook server.
  • make-app: Creates a boilerplate Frappe Application.
  • mariadb: Start the MySQL interactive console for the mysql site.
  • postgres: Start the PostgreSQL interactive console for the postgres site.
  • rebuild-global-search: Setup help table in the current site (called after migrate).
  • request: Make a request as Administrator with Arguements to a Path.
  • reset-perms: Reset permissions for all DocTypes to their default settings.
  • run-tests: Run Python tests on the specified site.
  • run-ui-tests: Run Cypress UI tests.
  • serve: Start the webserver for the bench.
  • set-config: Wrapper command to insert or update values in the site_config.json.
  • show-config: Show the configuration file of the site in a tabular form.
  • version: Show versions of all Applications installed on bench.
  • watch: Watch and concatenate JS and CSS files as and when they change.

Translation Commands

Set of commands to manage translations for your multi-lingual deployments. These commands are defined under the module frappe.commands.translate.

  • build-message-files: Build message files for translation.
  • get-untranslated: Get untranslated strings for language.
  • import-translations: Import translations from file in standard format.
  • new-language: Create lang-code.csv for given Frappe Application.
  • update-translations: Update translations for set language between files.