Apache Airflow code editor and file manager
Project description
Airflow Code Editor Plugin
A plugin for Apache Airflow that allows you to edit DAGs in browser. It provides a file managing interface within specified directories and it can be used to edit and download your files. If git support is enabled, the DAGs are stored in a Git repository. You may use it to view Git history, review local changes and commit.
System Requirements
- Airflow Versions
- 1.10.3 or newer
- git Versions (git is not required if git support is disabled)
- 2.0 or newer
Screenshots
Install Instructions
- Install the plugin
pip install airflow-code-editor
- (Optional) Install Black Python code formatter.
pip install black
-
Restart the Airflow Web Server
-
Open Admin - DAGs Code Editor
Config Options
You can edit your airflow.cfg adding any of the following settings in the [code_editor] section. All the settings are optional.
- git_enabled enable git support (default: True). If git is not installed, disable this option.
- git_cmd git command (path)
- git_default_args git arguments added to each call (default: -c color.ui=true)
- git_author_name human-readable name in the author/committer (default logged user first and last names)
- git_author_email email for the author/committer (default: logged user email)
- git_init_repo initialize a git repo in DAGs folder (default: True)
- root_directory root folder (default: Airflow DAGs folder)
- mount_name configure additional file folder name (mount point)
- mount_path configure additional file path
- line_length Python code formatter - max line length (default: 88)
- string_normalization Python code formatter - if true normalize string quotes and prefixes (default: False)
Example:
[code_editor]
git_enabled = True
git_cmd = /usr/bin/git
git_default_args = -c color.ui=true
git_init_repo = False
root_directory = /home/airflow/dags
line_length = 88
string_normalization = False
mount_name = data
mount_path = /home/airflow/data
mount1_name = logs
mount1_path = /home/airflow/logs
Development Instructions
-
Fork the repo
-
Clone it on the local machine
git clone https://github.com/andreax79/airflow-code-editor.git
cd airflow-code-editor
- Create and activate virtualenv
source ./scripts/activate.sh
- Make changes you need. You can start Airflow with this command:
./scripts/airflow.sh
- Run tests
./scripts/tests.sh
- Commit and push changes
git add .
git commit
git push
- Create pull request to the original repo
Links
- Apache Airflow - https://github.com/apache/airflow
- Codemirror, In-browser code editor - https://github.com/codemirror/codemirror
- Git WebUI, A standalone local web based user interface for git repositories - https://github.com/alberthier/git-webui
- Black, The Uncompromising Code Formatter - https://github.com/psf/black
- Vue.js - https://github.com/vuejs/vue
- Vue-Tree, Vue component that implements a TreeView control - https://github.com/grapoza/vue-tree
- Splitpanes - https://github.com/antoniandre/splitpanes
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Close
Hashes for airflow_code_editor-4.1.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 41be13120152dfe57f892a80e47e4432787d2d8de4d9de1d5d738df514dbb74a |
|
MD5 | 4250283d38bcd8399596523b03c1f594 |
|
BLAKE2b-256 | 5d51f9a92e1c4c95f4224ddbc0a45c490ef07f6c88369983f97825678f895aa5 |
Close
Hashes for airflow_code_editor-4.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | df60ae7ca807f719682cdac41497610b807f2fab156c2fe16ed59a243d0e96db |
|
MD5 | 0ec136883616e209ccbc476984d24e94 |
|
BLAKE2b-256 | 52d50ee85e7b865794d955e3c101be777c1c8afcaeee8f8d08681a45298bc42a |