Skip to content

Commit

Permalink
Merge pull request #24 from DouweM/airflow-dag-gen
Browse files Browse the repository at this point in the history
Read apps.yml directly from Airflow DAG generator
  • Loading branch information
DouweM authored Feb 21, 2024
2 parents bca2f43 + 14cdea4 commit c07eccb
Show file tree
Hide file tree
Showing 4 changed files with 66 additions and 188 deletions.
2 changes: 1 addition & 1 deletion apps.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
schedules:
- name: hello-world
interval: '0 * * * *' # On the hour
interval: '0 * * * *' # Every hour
job: hello-world

# - name: <app>
Expand Down
1 change: 0 additions & 1 deletion meltano.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,4 +8,3 @@ environments:
include_paths:
- "./plugins/*.meltano.yml"
- "./apps/**/pixbyt.yml"
- "./apps.yml"
186 changes: 0 additions & 186 deletions plugins/airflow/dags/meltano_dag_generator.py

This file was deleted.

65 changes: 65 additions & 0 deletions plugins/airflow/dags/pixbyt.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
import os
import yaml
import logging
from datetime import datetime, timedelta
from pathlib import Path

from airflow import DAG
from airflow.operators.bash import BashOperator

logger = logging.getLogger(__name__)

DEFAULT_DAG_OPTS = {
"catchup": False,
"max_active_runs": 1,
"default_args": {
"owner": "airflow",
"depends_on_past": False,
"email_on_failure": False,
"email_on_retry": False,
"catchup": False,
"retries": 1,
"retry_delay": timedelta(minutes=5),
"concurrency": 1,
"start_date": datetime(1970, 1, 1, 0, 0, 0),
}
}
DEFAULT_INTERVAL = "*/15 * * * *"

PROJECT_ROOT = os.getenv("MELTANO_PROJECT_ROOT", os.getcwd())
MELTANO_EXECUTABLE = ".meltano/run/bin"
APPS_FILENAME = "apps.yml"

apps_path = Path(PROJECT_ROOT).joinpath(APPS_FILENAME)
apps_config = yaml.safe_load(apps_path.read_text())

schedules = apps_config.get("schedules", [])

for schedule in schedules:
name = schedule.get("name")

if not name:
logger.warning("Skipping app without a name")
continue

interval = schedule.get("interval", DEFAULT_INTERVAL)
job = schedule.get("job", name)

env = schedule.get("env", {})
env = {k: str(v) for k, v in env.items()}

dag_id = name.replace("/", "--")
with DAG(dag_id, schedule=interval, **DEFAULT_DAG_OPTS) as dag:
cmd = f"{MELTANO_EXECUTABLE} run {job}"

task = BashOperator(
dag=dag,
task_id="run",
cwd=str(PROJECT_ROOT),
bash_command=cmd,
env=env,
append_env=True,
)
globals()[dag_id] = dag

logger.info(f"Created DAG '{dag_id}': interval='{interval}', cmd='{cmd}', env={env}")

0 comments on commit c07eccb

Please sign in to comment.