Metadata-Version: 2.1
Name: mara-cron
Version: 0.9.3
Summary: Lets you manage cron jobs via mara
Home-page: https://github.com/mara/mara-cron
Author: Mara contributors
License: MIT
Platform: UNKNOWN
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Provides-Extra: test
License-File: LICENSE

# Mara Cron

Mini package for managing cron jobs via mara.

&nbsp;

## Installation

To use the library directly:

```
pip install git+https://github.com/mara/mara-cron.git
```

&nbsp;

## Config of cron jobs

To configure cron jobs in mara you just need to add a new function `MARA_CRON_JOBS`
in your module or app in the `__init__.py` file.

Here is a sample which has two jobs:
1. the job `cleanup_data_folder` clears all data from the local folder `/data/`. This job is by default disabled.
2. the job `nightly` runs the root pipeline at 01:00 o'clock each day

_Note:_ The MaraJob job requires that you define the `PATH` environment variable in your crontab. Cron by default uses just `/usr/bin:/bin` which is not enough. I recommend using the distribution default e.g. `/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin`.

```python
def MARA_CRON_JOBS():
    from mara_cron.job import CronJob, MaraJob
    return [
        CronJob(id='cleanup_data_folder',
                description='Clean up the data folder',
                time_pattern='0 0 * * *',
                command='rm -rf /data/*',
                enabled=False),
        MaraJob(id='nightly',
                description="Nightly run of the BI system",
                time_pattern='0 1 * * *',
                command='mara_pipelines.ui.run'),
    ]
```

## Local config

Sample local config to activate crontab management in your mara app:

```python
from mara_app.monkey_patch import patch
import mara_cron.config

# Activates mara_cron jobs. If not set all jobs are
# by default disabled and can only be activated via
# executing:
#    flask mara_cron.enable --job-id "my_job_id"
patch(mara_cron.config.enabled)(lambda: True)

# Optional parameter to specify a mara instance name
# This is necessary to separate multiple environments running
# on the same user
patch(mara_cron.config.instance_name)(lambda: 'prod')
```

## CLI

This package contains the following cli commands:

| Command        | Description
| -------------- | --------------
| `mara_cron.enable --job-id "my_job_id" [--module "module_name"]` | Enables a specific job regardless of the configuration.
| `mara_cron.disable --job-id "my_job_id" [--module "module_name"]` | Disables a specific job.
| `mara_cron.list-crontab` | Lists the current cron tab settings
| `mara_cron.list-crontab --with-changes` | Lists the current cron tab including the changes not yet written
| `mara_cron.write-crontab` | Writes all not published changes to the crontab
| `mara_cron.clear-crontab` | Removes all mara jobs from the crontab. *Note* This applies to all instances !!!


