Metadata-Version: 2.4
Name: apache-airflow
Version: 2.11.0
Dynamic: Requires-Dist
Dynamic: Provides-Extra
Summary: Programmatically author, schedule and monitor data pipelines
Project-URL: Bug Tracker, https://github.com/apache/airflow/issues
Project-URL: Documentation, https://airflow.apache.org/docs/
Project-URL: Downloads, https://archive.apache.org/dist/airflow/
Project-URL: Homepage, https://airflow.apache.org/
Project-URL: Release Notes, https://airflow.apache.org/docs/apache-airflow/stable/release_notes.html
Project-URL: Slack Chat, https://s.apache.org/airflow-slack
Project-URL: Source Code, https://github.com/apache/airflow
Project-URL: X, https://x.com/ApacheAirflow
Project-URL: LinkedIn, https://www.linkedin.com/company/apache-airflow/
Project-URL: Mastodon, https://fosstodon.org/@airflow
Project-URL: Bluesky, https://bsky.app/profile/apache-airflow.bsky.social
Project-URL: YouTube, https://www.youtube.com/channel/UCSXwxpWZQ7XZ1WL3wqevChA/
Author-email: Apache Software Foundation <dev@airflow.apache.org>
Maintainer-email: Apache Software Foundation <dev@airflow.apache.org>
License-File: 3rd-party-licenses/LICENSE-bootstrap.txt
License-File: 3rd-party-licenses/LICENSE-bootstrap3-typeahead.txt
License-File: 3rd-party-licenses/LICENSE-d3-shape.txt
License-File: 3rd-party-licenses/LICENSE-d3-tip.txt
License-File: 3rd-party-licenses/LICENSE-d3js.txt
License-File: 3rd-party-licenses/LICENSE-dagre-d3.txt
License-File: 3rd-party-licenses/LICENSE-datatables.txt
License-File: 3rd-party-licenses/LICENSE-elasticmock.txt
License-File: 3rd-party-licenses/LICENSE-eonasdan-bootstrap-datetimepicker.txt
License-File: 3rd-party-licenses/LICENSE-flask-kerberos.txt
License-File: 3rd-party-licenses/LICENSE-hue.txt
License-File: 3rd-party-licenses/LICENSE-jqclock.txt
License-File: 3rd-party-licenses/LICENSE-jquery.txt
License-File: 3rd-party-licenses/LICENSE-moment.txt
License-File: 3rd-party-licenses/LICENSE-normalize.txt
License-File: 3rd-party-licenses/LICENSE-pytest-capture-warnings.txt
License-File: 3rd-party-licenses/LICENSE-reproducible.txt
License-File: 3rd-party-licenses/LICENSES-ui.txt
License-File: LICENSE
Keywords: airflow,automation,dag,data,orchestration,pipelines,workflow
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Console
Classifier: Environment :: Web Environment
Classifier: Framework :: Apache Airflow
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: System Administrators
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: System :: Monitoring
Requires-Python: <3.13,>=3.9
Requires-Dist: alembic>=1.13.1, <2.0
Requires-Dist: argcomplete>=1.10
Requires-Dist: asgiref>=2.3.0
Requires-Dist: attrs>=22.1.0
Requires-Dist: blinker>=1.6.2
Requires-Dist: colorlog>=6.8.2
Requires-Dist: configupdater>=3.1.1
Requires-Dist: connexion[flask]>=2.14.2,<3.0
Requires-Dist: cron-descriptor>=1.2.24
Requires-Dist: croniter>=2.0.2
Requires-Dist: cryptography>=41.0.0
Requires-Dist: deprecated>=1.2.13
Requires-Dist: dill>=0.2.2
Requires-Dist: eval-type-backport>=0.2.0;python_version<"3.10"
Requires-Dist: flask-caching>=2.0.0
Requires-Dist: flask-session>=0.4.0,<0.6
Requires-Dist: flask-wtf>=1.1.0
Requires-Dist: flask>=2.2.1,<2.3
Requires-Dist: fsspec>=2023.10.0
Requires-Dist: google-re2>=1.0;python_version<"3.12"
Requires-Dist: google-re2>=1.1;python_version>="3.12"
Requires-Dist: gunicorn>=20.1.0
Requires-Dist: httpx>=0.25.0
Requires-Dist: importlib_metadata>=6.5;python_version<"3.12"
Requires-Dist: importlib_resources>=5.2,!=6.2.0,!=6.3.0,!=6.3.1;python_version<"3.9"
Requires-Dist: itsdangerous>=2.0
Requires-Dist: jinja2>=3.0.0
Requires-Dist: jsonschema>=4.18.0
Requires-Dist: lazy-object-proxy>=1.2.0
Requires-Dist: linkify-it-py>=2.0.0
Requires-Dist: lockfile>=0.12.2
Requires-Dist: markdown-it-py>=2.1.0
Requires-Dist: markupsafe>=1.1.1
Requires-Dist: marshmallow-oneofschema>=2.0.1
Requires-Dist: mdit-py-plugins>=0.3.0
Requires-Dist: methodtools>=0.4.7
Requires-Dist: opentelemetry-api>=1.24.0
Requires-Dist: opentelemetry-exporter-otlp>=1.24.0
Requires-Dist: packaging>=23.0
Requires-Dist: pathspec>=0.9.0
Requires-Dist: pendulum>=2.1.2,<4.0;python_version<"3.12"
Requires-Dist: pendulum>=3.0.0,<4.0;python_version>="3.12"
Requires-Dist: pluggy>=1.5.0
Requires-Dist: psutil>=5.8.0
Requires-Dist: pygments>=2.0.1
Requires-Dist: pyjwt>=2.0.0
Requires-Dist: python-daemon>=3.0.0
Requires-Dist: python-dateutil>=2.7.0
Requires-Dist: python-nvd3>=0.15.0
Requires-Dist: python-slugify>=5.0
Requires-Dist: requests>=2.27.0,<3
Requires-Dist: requests-toolbelt>=0.4.0
Requires-Dist: rfc3339-validator>=0.1.4
Requires-Dist: rich-argparse>=1.0.0
Requires-Dist: rich>=12.4.4
Requires-Dist: setproctitle>=1.3.3
Requires-Dist: sqlalchemy>=1.4.36,<2.0
Requires-Dist: sqlalchemy-jsonfield>=1.0
Requires-Dist: tabulate>=0.7.5
Requires-Dist: tenacity>=8.0.0,!=8.2.0
Requires-Dist: termcolor>=1.1.0
Requires-Dist: universal-pathlib>=0.2.2,!=0.2.4
Requires-Dist: werkzeug>=2.0,<3
Requires-Dist: apache-airflow-providers-common-compat
Requires-Dist: apache-airflow-providers-common-io
Requires-Dist: apache-airflow-providers-common-sql
Requires-Dist: apache-airflow-providers-fab>=1.0.2
Requires-Dist: apache-airflow-providers-ftp
Requires-Dist: apache-airflow-providers-http
Requires-Dist: apache-airflow-providers-imap
Requires-Dist: apache-airflow-providers-smtp
Requires-Dist: apache-airflow-providers-sqlite
Provides-Extra: aiobotocore
Requires-Dist: aiobotocore>=2.9.0; extra == 'aiobotocore'
Provides-Extra: async
Requires-Dist: eventlet>=0.33.3; extra == 'async'
Requires-Dist: gevent>=0.13; extra == 'async'
Requires-Dist: greenlet>=0.4.9; extra == 'async'
Provides-Extra: apache-atlas
Requires-Dist: atlasclient>=0.1.2; extra == 'apache-atlas'
Provides-Extra: apache-webhdfs
Requires-Dist: hdfs[avro,dataframe,kerberos]>=2.0.4; extra == 'apache-webhdfs'
Provides-Extra: cgroups
Requires-Dist: cgroupspy>=0.2.2; extra == 'cgroups'
Provides-Extra: cloudpickle
Requires-Dist: cloudpickle; extra == 'cloudpickle'
Provides-Extra: deprecated-api
Requires-Dist: requests>=2.27.0,<3; extra == 'deprecated-api'
Provides-Extra: github-enterprise
Requires-Dist: apache-airflow[fab]; extra == 'github-enterprise'
Requires-Dist: authlib>=1.0.0; extra == 'github-enterprise'
Provides-Extra: google-auth
Requires-Dist: apache-airflow[fab]; extra == 'google-auth'
Requires-Dist: authlib>=1.0.0; extra == 'google-auth'
Provides-Extra: graphviz
Requires-Dist: graphviz>=0.12; extra == 'graphviz'
Provides-Extra: kerberos
Requires-Dist: pykerberos>=1.1.13; extra == 'kerberos'
Requires-Dist: requests-kerberos>=0.10.0; extra == 'kerberos'
Requires-Dist: thrift-sasl>=0.2.0; extra == 'kerberos'
Provides-Extra: ldap
Requires-Dist: ldap3>=2.5.1; extra == 'ldap'
Requires-Dist: python-ldap; extra == 'ldap'
Provides-Extra: leveldb
Requires-Dist: plyvel>=1.5.1; (sys_platform != 'darwin') and extra == 'leveldb'
Provides-Extra: otel
Requires-Dist: opentelemetry-exporter-prometheus; extra == 'otel'
Provides-Extra: pandas
Requires-Dist: pandas>=1.2.5,<2.2; extra == 'pandas'
Provides-Extra: password
Requires-Dist: bcrypt>=2.0.0; extra == 'password'
Requires-Dist: flask-bcrypt>=0.7.1; extra == 'password'
Provides-Extra: pydantic
Requires-Dist: pydantic>=2.3.0; extra == 'pydantic'
Provides-Extra: rabbitmq
Requires-Dist: amqp; extra == 'rabbitmq'
Provides-Extra: s3fs
Requires-Dist: s3fs>=2023.10.0; extra == 's3fs'
Provides-Extra: saml
Requires-Dist: python3-saml>=1.16.0; extra == 'saml'
Provides-Extra: sentry
Requires-Dist: blinker>=1.1; extra == 'sentry'
Requires-Dist: sentry-sdk>=1.32.0,!=1.33.0; extra == 'sentry'
Provides-Extra: statsd
Requires-Dist: statsd>=3.3.0; extra == 'statsd'
Provides-Extra: uv
Requires-Dist: uv>=0.1.32; extra == 'uv'
Provides-Extra: virtualenv
Requires-Dist: virtualenv; extra == 'virtualenv'
Provides-Extra: all-dbs
Requires-Dist: apache-airflow[apache-cassandra]; extra == 'all-dbs'
Requires-Dist: apache-airflow[apache-drill]; extra == 'all-dbs'
Requires-Dist: apache-airflow[apache-druid]; extra == 'all-dbs'
Requires-Dist: apache-airflow[apache-hdfs]; extra == 'all-dbs'
Requires-Dist: apache-airflow[apache-hive]; extra == 'all-dbs'
Requires-Dist: apache-airflow[apache-impala]; extra == 'all-dbs'
Requires-Dist: apache-airflow[apache-pinot]; extra == 'all-dbs'
Requires-Dist: apache-airflow[arangodb]; extra == 'all-dbs'
Requires-Dist: apache-airflow[cloudant]; extra == 'all-dbs'
Requires-Dist: apache-airflow[databricks]; extra == 'all-dbs'
Requires-Dist: apache-airflow[exasol]; extra == 'all-dbs'
Requires-Dist: apache-airflow[influxdb]; extra == 'all-dbs'
Requires-Dist: apache-airflow[microsoft-mssql]; extra == 'all-dbs'
Requires-Dist: apache-airflow[mongo]; extra == 'all-dbs'
Requires-Dist: apache-airflow[mysql]; extra == 'all-dbs'
Requires-Dist: apache-airflow[neo4j]; extra == 'all-dbs'
Requires-Dist: apache-airflow[postgres]; extra == 'all-dbs'
Requires-Dist: apache-airflow[presto]; extra == 'all-dbs'
Requires-Dist: apache-airflow[trino]; extra == 'all-dbs'
Requires-Dist: apache-airflow[vertica]; extra == 'all-dbs'
Provides-Extra: atlas
Requires-Dist: apache-airflow[apache-atlas]; extra == 'atlas'
Provides-Extra: aws
Requires-Dist: apache-airflow[amazon]; extra == 'aws'
Provides-Extra: azure
Requires-Dist: apache-airflow[microsoft-azure]; extra == 'azure'
Provides-Extra: cassandra
Requires-Dist: apache-airflow[apache-cassandra]; extra == 'cassandra'
Provides-Extra: crypto
Provides-Extra: druid
Requires-Dist: apache-airflow[apache-druid]; extra == 'druid'
Provides-Extra: gcp
Requires-Dist: apache-airflow[google]; extra == 'gcp'
Provides-Extra: gcp-api
Requires-Dist: apache-airflow[google]; extra == 'gcp-api'
Provides-Extra: hdfs
Requires-Dist: apache-airflow[apache-hdfs]; extra == 'hdfs'
Provides-Extra: hive
Requires-Dist: apache-airflow[apache-hive]; extra == 'hive'
Provides-Extra: kubernetes
Requires-Dist: apache-airflow[cncf-kubernetes]; extra == 'kubernetes'
Provides-Extra: mssql
Requires-Dist: apache-airflow[microsoft-mssql]; extra == 'mssql'
Provides-Extra: pinot
Requires-Dist: apache-airflow[apache-pinot]; extra == 'pinot'
Provides-Extra: s3
Requires-Dist: apache-airflow[amazon]; extra == 's3'
Provides-Extra: spark
Requires-Dist: apache-airflow[apache-spark]; extra == 'spark'
Provides-Extra: webhdfs
Requires-Dist: apache-airflow[apache-webhdfs]; extra == 'webhdfs'
Provides-Extra: winrm
Requires-Dist: apache-airflow[microsoft-winrm]; extra == 'winrm'
Provides-Extra: airbyte
Requires-Dist: apache-airflow-providers-airbyte; extra == 'airbyte'
Provides-Extra: alibaba
Requires-Dist: apache-airflow-providers-alibaba; extra == 'alibaba'
Provides-Extra: amazon
Requires-Dist: apache-airflow-providers-amazon; extra == 'amazon'
Provides-Extra: apache-beam
Requires-Dist: apache-airflow-providers-apache-beam; (python_version != "3.12") and extra == 'apache-beam'
Provides-Extra: apache-cassandra
Requires-Dist: apache-airflow-providers-apache-cassandra; extra == 'apache-cassandra'
Provides-Extra: apache-drill
Requires-Dist: apache-airflow-providers-apache-drill; extra == 'apache-drill'
Provides-Extra: apache-druid
Requires-Dist: apache-airflow-providers-apache-druid; extra == 'apache-druid'
Provides-Extra: apache-flink
Requires-Dist: apache-airflow-providers-apache-flink; extra == 'apache-flink'
Provides-Extra: apache-hdfs
Requires-Dist: apache-airflow-providers-apache-hdfs; extra == 'apache-hdfs'
Provides-Extra: apache-hive
Requires-Dist: apache-airflow-providers-apache-hive; extra == 'apache-hive'
Provides-Extra: apache-iceberg
Requires-Dist: apache-airflow-providers-apache-iceberg; extra == 'apache-iceberg'
Provides-Extra: apache-impala
Requires-Dist: apache-airflow-providers-apache-impala; extra == 'apache-impala'
Provides-Extra: apache-kafka
Requires-Dist: apache-airflow-providers-apache-kafka; extra == 'apache-kafka'
Provides-Extra: apache-kylin
Requires-Dist: apache-airflow-providers-apache-kylin; extra == 'apache-kylin'
Provides-Extra: apache-livy
Requires-Dist: apache-airflow-providers-apache-livy; extra == 'apache-livy'
Provides-Extra: apache-pig
Requires-Dist: apache-airflow-providers-apache-pig; extra == 'apache-pig'
Provides-Extra: apache-pinot
Requires-Dist: apache-airflow-providers-apache-pinot; extra == 'apache-pinot'
Provides-Extra: apache-spark
Requires-Dist: apache-airflow-providers-apache-spark; extra == 'apache-spark'
Provides-Extra: apprise
Requires-Dist: apache-airflow-providers-apprise; extra == 'apprise'
Provides-Extra: arangodb
Requires-Dist: apache-airflow-providers-arangodb; extra == 'arangodb'
Provides-Extra: asana
Requires-Dist: apache-airflow-providers-asana; extra == 'asana'
Provides-Extra: atlassian-jira
Requires-Dist: apache-airflow-providers-atlassian-jira; extra == 'atlassian-jira'
Provides-Extra: celery
Requires-Dist: apache-airflow-providers-celery; extra == 'celery'
Provides-Extra: cloudant
Requires-Dist: apache-airflow-providers-cloudant; extra == 'cloudant'
Provides-Extra: cncf-kubernetes
Requires-Dist: apache-airflow-providers-cncf-kubernetes; extra == 'cncf-kubernetes'
Provides-Extra: cohere
Requires-Dist: apache-airflow-providers-cohere; extra == 'cohere'
Provides-Extra: common-compat
Requires-Dist: apache-airflow-providers-common-compat; extra == 'common-compat'
Provides-Extra: common-io
Requires-Dist: apache-airflow-providers-common-io; extra == 'common-io'
Provides-Extra: common-sql
Requires-Dist: apache-airflow-providers-common-sql; extra == 'common-sql'
Provides-Extra: databricks
Requires-Dist: apache-airflow-providers-databricks; extra == 'databricks'
Provides-Extra: datadog
Requires-Dist: apache-airflow-providers-datadog; extra == 'datadog'
Provides-Extra: dbt-cloud
Requires-Dist: apache-airflow-providers-dbt-cloud; extra == 'dbt-cloud'
Provides-Extra: dingding
Requires-Dist: apache-airflow-providers-dingding; extra == 'dingding'
Provides-Extra: discord
Requires-Dist: apache-airflow-providers-discord; extra == 'discord'
Provides-Extra: docker
Requires-Dist: apache-airflow-providers-docker; extra == 'docker'
Provides-Extra: elasticsearch
Requires-Dist: apache-airflow-providers-elasticsearch; extra == 'elasticsearch'
Provides-Extra: exasol
Requires-Dist: apache-airflow-providers-exasol; extra == 'exasol'
Provides-Extra: fab
Requires-Dist: apache-airflow-providers-fab; extra == 'fab'
Provides-Extra: facebook
Requires-Dist: apache-airflow-providers-facebook; extra == 'facebook'
Provides-Extra: ftp
Requires-Dist: apache-airflow-providers-ftp; extra == 'ftp'
Provides-Extra: github
Requires-Dist: apache-airflow-providers-github; extra == 'github'
Provides-Extra: google
Requires-Dist: apache-airflow-providers-google; extra == 'google'
Provides-Extra: grpc
Requires-Dist: apache-airflow-providers-grpc; extra == 'grpc'
Provides-Extra: hashicorp
Requires-Dist: apache-airflow-providers-hashicorp; extra == 'hashicorp'
Provides-Extra: http
Requires-Dist: apache-airflow-providers-http; extra == 'http'
Provides-Extra: imap
Requires-Dist: apache-airflow-providers-imap; extra == 'imap'
Provides-Extra: influxdb
Requires-Dist: apache-airflow-providers-influxdb; extra == 'influxdb'
Provides-Extra: jdbc
Requires-Dist: apache-airflow-providers-jdbc; extra == 'jdbc'
Provides-Extra: jenkins
Requires-Dist: apache-airflow-providers-jenkins; extra == 'jenkins'
Provides-Extra: microsoft-azure
Requires-Dist: apache-airflow-providers-microsoft-azure; extra == 'microsoft-azure'
Provides-Extra: microsoft-mssql
Requires-Dist: apache-airflow-providers-microsoft-mssql; extra == 'microsoft-mssql'
Provides-Extra: microsoft-psrp
Requires-Dist: apache-airflow-providers-microsoft-psrp; extra == 'microsoft-psrp'
Provides-Extra: microsoft-winrm
Requires-Dist: apache-airflow-providers-microsoft-winrm; extra == 'microsoft-winrm'
Provides-Extra: mongo
Requires-Dist: apache-airflow-providers-mongo; extra == 'mongo'
Provides-Extra: mysql
Requires-Dist: apache-airflow-providers-mysql; extra == 'mysql'
Provides-Extra: neo4j
Requires-Dist: apache-airflow-providers-neo4j; extra == 'neo4j'
Provides-Extra: odbc
Requires-Dist: apache-airflow-providers-odbc; extra == 'odbc'
Provides-Extra: openai
Requires-Dist: apache-airflow-providers-openai; extra == 'openai'
Provides-Extra: openfaas
Requires-Dist: apache-airflow-providers-openfaas; extra == 'openfaas'
Provides-Extra: openlineage
Requires-Dist: apache-airflow-providers-openlineage; extra == 'openlineage'
Provides-Extra: opensearch
Requires-Dist: apache-airflow-providers-opensearch; extra == 'opensearch'
Provides-Extra: opsgenie
Requires-Dist: apache-airflow-providers-opsgenie; extra == 'opsgenie'
Provides-Extra: oracle
Requires-Dist: apache-airflow-providers-oracle; extra == 'oracle'
Provides-Extra: pagerduty
Requires-Dist: apache-airflow-providers-pagerduty; extra == 'pagerduty'
Provides-Extra: papermill
Requires-Dist: apache-airflow-providers-papermill; (python_version != "3.12") and extra == 'papermill'
Provides-Extra: pgvector
Requires-Dist: apache-airflow-providers-pgvector; extra == 'pgvector'
Provides-Extra: pinecone
Requires-Dist: apache-airflow-providers-pinecone; extra == 'pinecone'
Provides-Extra: postgres
Requires-Dist: apache-airflow-providers-postgres; extra == 'postgres'
Provides-Extra: presto
Requires-Dist: apache-airflow-providers-presto; extra == 'presto'
Provides-Extra: qdrant
Requires-Dist: apache-airflow-providers-qdrant; extra == 'qdrant'
Provides-Extra: redis
Requires-Dist: apache-airflow-providers-redis; extra == 'redis'
Provides-Extra: salesforce
Requires-Dist: apache-airflow-providers-salesforce; extra == 'salesforce'
Provides-Extra: samba
Requires-Dist: apache-airflow-providers-samba; extra == 'samba'
Provides-Extra: segment
Requires-Dist: apache-airflow-providers-segment; extra == 'segment'
Provides-Extra: sendgrid
Requires-Dist: apache-airflow-providers-sendgrid; extra == 'sendgrid'
Provides-Extra: sftp
Requires-Dist: apache-airflow-providers-sftp; extra == 'sftp'
Provides-Extra: singularity
Requires-Dist: apache-airflow-providers-singularity; extra == 'singularity'
Provides-Extra: slack
Requires-Dist: apache-airflow-providers-slack; extra == 'slack'
Provides-Extra: smtp
Requires-Dist: apache-airflow-providers-smtp; extra == 'smtp'
Provides-Extra: snowflake
Requires-Dist: apache-airflow-providers-snowflake; extra == 'snowflake'
Provides-Extra: sqlite
Requires-Dist: apache-airflow-providers-sqlite; extra == 'sqlite'
Provides-Extra: ssh
Requires-Dist: apache-airflow-providers-ssh; extra == 'ssh'
Provides-Extra: tableau
Requires-Dist: apache-airflow-providers-tableau; extra == 'tableau'
Provides-Extra: tabular
Requires-Dist: apache-airflow-providers-tabular; extra == 'tabular'
Provides-Extra: telegram
Requires-Dist: apache-airflow-providers-telegram; extra == 'telegram'
Provides-Extra: teradata
Requires-Dist: apache-airflow-providers-teradata; extra == 'teradata'
Provides-Extra: trino
Requires-Dist: apache-airflow-providers-trino; extra == 'trino'
Provides-Extra: vertica
Requires-Dist: apache-airflow-providers-vertica; extra == 'vertica'
Provides-Extra: weaviate
Requires-Dist: apache-airflow-providers-weaviate; extra == 'weaviate'
Provides-Extra: yandex
Requires-Dist: apache-airflow-providers-yandex; extra == 'yandex'
Provides-Extra: ydb
Requires-Dist: apache-airflow-providers-ydb; extra == 'ydb'
Provides-Extra: zendesk
Requires-Dist: apache-airflow-providers-zendesk; extra == 'zendesk'
Provides-Extra: all-core
Requires-Dist: apache-airflow[aiobotocore]; extra == 'all-core'
Requires-Dist: apache-airflow[apache-atlas]; extra == 'all-core'
Requires-Dist: apache-airflow[apache-webhdfs]; extra == 'all-core'
Requires-Dist: apache-airflow[async]; extra == 'all-core'
Requires-Dist: apache-airflow[cgroups]; extra == 'all-core'
Requires-Dist: apache-airflow[cloudpickle]; extra == 'all-core'
Requires-Dist: apache-airflow[deprecated-api]; extra == 'all-core'
Requires-Dist: apache-airflow[github-enterprise]; extra == 'all-core'
Requires-Dist: apache-airflow[google-auth]; extra == 'all-core'
Requires-Dist: apache-airflow[graphviz]; extra == 'all-core'
Requires-Dist: apache-airflow[kerberos]; extra == 'all-core'
Requires-Dist: apache-airflow[ldap]; extra == 'all-core'
Requires-Dist: apache-airflow[leveldb]; extra == 'all-core'
Requires-Dist: apache-airflow[otel]; extra == 'all-core'
Requires-Dist: apache-airflow[pandas]; extra == 'all-core'
Requires-Dist: apache-airflow[password]; extra == 'all-core'
Requires-Dist: apache-airflow[pydantic]; extra == 'all-core'
Requires-Dist: apache-airflow[rabbitmq]; extra == 'all-core'
Requires-Dist: apache-airflow[s3fs]; extra == 'all-core'
Requires-Dist: apache-airflow[saml]; extra == 'all-core'
Requires-Dist: apache-airflow[sentry]; extra == 'all-core'
Requires-Dist: apache-airflow[statsd]; extra == 'all-core'
Requires-Dist: apache-airflow[uv]; extra == 'all-core'
Requires-Dist: apache-airflow[virtualenv]; extra == 'all-core'
Provides-Extra: all
Requires-Dist: apache-airflow[aiobotocore]; extra == 'all'
Requires-Dist: apache-airflow[airbyte]; extra == 'all'
Requires-Dist: apache-airflow[alibaba]; extra == 'all'
Requires-Dist: apache-airflow[all-dbs]; extra == 'all'
Requires-Dist: apache-airflow[amazon]; extra == 'all'
Requires-Dist: apache-airflow[apache-atlas]; extra == 'all'
Requires-Dist: apache-airflow[apache-beam]; extra == 'all'
Requires-Dist: apache-airflow[apache-cassandra]; extra == 'all'
Requires-Dist: apache-airflow[apache-drill]; extra == 'all'
Requires-Dist: apache-airflow[apache-druid]; extra == 'all'
Requires-Dist: apache-airflow[apache-flink]; extra == 'all'
Requires-Dist: apache-airflow[apache-hdfs]; extra == 'all'
Requires-Dist: apache-airflow[apache-hive]; extra == 'all'
Requires-Dist: apache-airflow[apache-iceberg]; extra == 'all'
Requires-Dist: apache-airflow[apache-impala]; extra == 'all'
Requires-Dist: apache-airflow[apache-kafka]; extra == 'all'
Requires-Dist: apache-airflow[apache-kylin]; extra == 'all'
Requires-Dist: apache-airflow[apache-livy]; extra == 'all'
Requires-Dist: apache-airflow[apache-pig]; extra == 'all'
Requires-Dist: apache-airflow[apache-pinot]; extra == 'all'
Requires-Dist: apache-airflow[apache-spark]; extra == 'all'
Requires-Dist: apache-airflow[apache-webhdfs]; extra == 'all'
Requires-Dist: apache-airflow[apprise]; extra == 'all'
Requires-Dist: apache-airflow[arangodb]; extra == 'all'
Requires-Dist: apache-airflow[asana]; extra == 'all'
Requires-Dist: apache-airflow[async]; extra == 'all'
Requires-Dist: apache-airflow[atlassian-jira]; extra == 'all'
Requires-Dist: apache-airflow[celery]; extra == 'all'
Requires-Dist: apache-airflow[cgroups]; extra == 'all'
Requires-Dist: apache-airflow[cloudant]; extra == 'all'
Requires-Dist: apache-airflow[cloudpickle]; extra == 'all'
Requires-Dist: apache-airflow[cncf-kubernetes]; extra == 'all'
Requires-Dist: apache-airflow[cohere]; extra == 'all'
Requires-Dist: apache-airflow[common-compat]; extra == 'all'
Requires-Dist: apache-airflow[common-io]; extra == 'all'
Requires-Dist: apache-airflow[common-sql]; extra == 'all'
Requires-Dist: apache-airflow[databricks]; extra == 'all'
Requires-Dist: apache-airflow[datadog]; extra == 'all'
Requires-Dist: apache-airflow[dbt-cloud]; extra == 'all'
Requires-Dist: apache-airflow[deprecated-api]; extra == 'all'
Requires-Dist: apache-airflow[dingding]; extra == 'all'
Requires-Dist: apache-airflow[discord]; extra == 'all'
Requires-Dist: apache-airflow[docker]; extra == 'all'
Requires-Dist: apache-airflow[elasticsearch]; extra == 'all'
Requires-Dist: apache-airflow[exasol]; extra == 'all'
Requires-Dist: apache-airflow[fab]; extra == 'all'
Requires-Dist: apache-airflow[facebook]; extra == 'all'
Requires-Dist: apache-airflow[ftp]; extra == 'all'
Requires-Dist: apache-airflow[github]; extra == 'all'
Requires-Dist: apache-airflow[github-enterprise]; extra == 'all'
Requires-Dist: apache-airflow[google]; extra == 'all'
Requires-Dist: apache-airflow[google-auth]; extra == 'all'
Requires-Dist: apache-airflow[graphviz]; extra == 'all'
Requires-Dist: apache-airflow[grpc]; extra == 'all'
Requires-Dist: apache-airflow[hashicorp]; extra == 'all'
Requires-Dist: apache-airflow[http]; extra == 'all'
Requires-Dist: apache-airflow[imap]; extra == 'all'
Requires-Dist: apache-airflow[influxdb]; extra == 'all'
Requires-Dist: apache-airflow[jdbc]; extra == 'all'
Requires-Dist: apache-airflow[jenkins]; extra == 'all'
Requires-Dist: apache-airflow[kerberos]; extra == 'all'
Requires-Dist: apache-airflow[ldap]; extra == 'all'
Requires-Dist: apache-airflow[leveldb]; extra == 'all'
Requires-Dist: apache-airflow[microsoft-azure]; extra == 'all'
Requires-Dist: apache-airflow[microsoft-mssql]; extra == 'all'
Requires-Dist: apache-airflow[microsoft-psrp]; extra == 'all'
Requires-Dist: apache-airflow[microsoft-winrm]; extra == 'all'
Requires-Dist: apache-airflow[mongo]; extra == 'all'
Requires-Dist: apache-airflow[mysql]; extra == 'all'
Requires-Dist: apache-airflow[neo4j]; extra == 'all'
Requires-Dist: apache-airflow[odbc]; extra == 'all'
Requires-Dist: apache-airflow[openai]; extra == 'all'
Requires-Dist: apache-airflow[openfaas]; extra == 'all'
Requires-Dist: apache-airflow[openlineage]; extra == 'all'
Requires-Dist: apache-airflow[opensearch]; extra == 'all'
Requires-Dist: apache-airflow[opsgenie]; extra == 'all'
Requires-Dist: apache-airflow[oracle]; extra == 'all'
Requires-Dist: apache-airflow[otel]; extra == 'all'
Requires-Dist: apache-airflow[pagerduty]; extra == 'all'
Requires-Dist: apache-airflow[pandas]; extra == 'all'
Requires-Dist: apache-airflow[papermill]; extra == 'all'
Requires-Dist: apache-airflow[password]; extra == 'all'
Requires-Dist: apache-airflow[pgvector]; extra == 'all'
Requires-Dist: apache-airflow[pinecone]; extra == 'all'
Requires-Dist: apache-airflow[postgres]; extra == 'all'
Requires-Dist: apache-airflow[presto]; extra == 'all'
Requires-Dist: apache-airflow[pydantic]; extra == 'all'
Requires-Dist: apache-airflow[qdrant]; extra == 'all'
Requires-Dist: apache-airflow[rabbitmq]; extra == 'all'
Requires-Dist: apache-airflow[redis]; extra == 'all'
Requires-Dist: apache-airflow[s3fs]; extra == 'all'
Requires-Dist: apache-airflow[salesforce]; extra == 'all'
Requires-Dist: apache-airflow[samba]; extra == 'all'
Requires-Dist: apache-airflow[saml]; extra == 'all'
Requires-Dist: apache-airflow[segment]; extra == 'all'
Requires-Dist: apache-airflow[sendgrid]; extra == 'all'
Requires-Dist: apache-airflow[sentry]; extra == 'all'
Requires-Dist: apache-airflow[sftp]; extra == 'all'
Requires-Dist: apache-airflow[singularity]; extra == 'all'
Requires-Dist: apache-airflow[slack]; extra == 'all'
Requires-Dist: apache-airflow[smtp]; extra == 'all'
Requires-Dist: apache-airflow[snowflake]; extra == 'all'
Requires-Dist: apache-airflow[sqlite]; extra == 'all'
Requires-Dist: apache-airflow[ssh]; extra == 'all'
Requires-Dist: apache-airflow[statsd]; extra == 'all'
Requires-Dist: apache-airflow[tableau]; extra == 'all'
Requires-Dist: apache-airflow[tabular]; extra == 'all'
Requires-Dist: apache-airflow[telegram]; extra == 'all'
Requires-Dist: apache-airflow[teradata]; extra == 'all'
Requires-Dist: apache-airflow[trino]; extra == 'all'
Requires-Dist: apache-airflow[uv]; extra == 'all'
Requires-Dist: apache-airflow[vertica]; extra == 'all'
Requires-Dist: apache-airflow[virtualenv]; extra == 'all'
Requires-Dist: apache-airflow[weaviate]; extra == 'all'
Requires-Dist: apache-airflow[yandex]; extra == 'all'
Requires-Dist: apache-airflow[ydb]; extra == 'all'
Requires-Dist: apache-airflow[zendesk]; extra == 'all'
Provides-Extra: devel-ci
Requires-Dist: aiobotocore>=2.9.0; extra == 'devel-ci'
Requires-Dist: aiofiles>=23.2.0; extra == 'devel-ci'
Requires-Dist: aioresponses>=0.7.6; extra == 'devel-ci'
Requires-Dist: amqp; extra == 'devel-ci'
Requires-Dist: astroid>=3; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: atlasclient>=0.1.2; extra == 'devel-ci'
Requires-Dist: authlib>=1.0.0; extra == 'devel-ci'
Requires-Dist: backports-zoneinfo>=0.2.1; (python_version < "3.9") and extra == 'devel-ci'
Requires-Dist: bcrypt>=2.0.0; extra == 'devel-ci'
Requires-Dist: beautifulsoup4>=4.7.1; extra == 'devel-ci'
Requires-Dist: black>=23.12.0; extra == 'devel-ci'
Requires-Dist: blinker>=1.1; extra == 'devel-ci'
Requires-Dist: blinker>=1.7.0; extra == 'devel-ci'
Requires-Dist: cgroupspy>=0.2.2; extra == 'devel-ci'
Requires-Dist: checksumdir>=1.2.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: click>=8.0; extra == 'devel-ci'
Requires-Dist: click>=8.1.8; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: cloudpickle; extra == 'devel-ci'
Requires-Dist: coverage>=7.4.0; extra == 'devel-ci'
Requires-Dist: diagrams>=0.23.4; extra == 'devel-ci'
Requires-Dist: docutils>=0.21; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: duckdb>=0.10.0; (python_version >= "3.12") and extra == 'devel-ci'
Requires-Dist: duckdb>=0.9.0; (python_version < "3.12") and extra == 'devel-ci'
Requires-Dist: eralchemy2>=1.3.8; extra == 'devel-ci'
Requires-Dist: eventlet>=0.33.3; extra == 'devel-ci'
Requires-Dist: flask-bcrypt>=0.7.1; extra == 'devel-ci'
Requires-Dist: gevent>=0.13; extra == 'devel-ci'
Requires-Dist: gitpython>=3.1.40; extra == 'devel-ci'
Requires-Dist: graphviz>=0.12; extra == 'devel-ci'
Requires-Dist: greenlet>=0.4.9; extra == 'devel-ci'
Requires-Dist: hatch>=1.9.1; extra == 'devel-ci'
Requires-Dist: hdfs[avro,dataframe,kerberos]>=2.0.4; extra == 'devel-ci'
Requires-Dist: incremental>=22.10.0,!=24.7.0,!=24.7.1; extra == 'devel-ci'
Requires-Dist: ipdb>=0.13.13; extra == 'devel-ci'
Requires-Dist: jmespath>=0.7.0; extra == 'devel-ci'
Requires-Dist: ldap3>=2.5.1; extra == 'devel-ci'
Requires-Dist: mypy==1.9.0; extra == 'devel-ci'
Requires-Dist: opentelemetry-exporter-prometheus; extra == 'devel-ci'
Requires-Dist: pandas>=1.2.5,<2.2; extra == 'devel-ci'
Requires-Dist: pipdeptree>=2.13.1; extra == 'devel-ci'
Requires-Dist: plyvel>=1.5.1; (sys_platform != "darwin") and extra == 'devel-ci'
Requires-Dist: pre-commit>=3.5.0; extra == 'devel-ci'
Requires-Dist: pydantic>=2.3.0; extra == 'devel-ci'
Requires-Dist: pygithub>=2.1.1; extra == 'devel-ci'
Requires-Dist: pykerberos>=1.1.13; extra == 'devel-ci'
Requires-Dist: pytest-asyncio>=0.23.6; extra == 'devel-ci'
Requires-Dist: pytest-cov>=4.1.0; extra == 'devel-ci'
Requires-Dist: pytest-custom-exit-code>=0.3.0; extra == 'devel-ci'
Requires-Dist: pytest-icdiff>=0.9; extra == 'devel-ci'
Requires-Dist: pytest-instafail>=0.5.0; extra == 'devel-ci'
Requires-Dist: pytest-mock>=3.12.0; extra == 'devel-ci'
Requires-Dist: pytest-rerunfailures>=13.0; extra == 'devel-ci'
Requires-Dist: pytest-timeouts>=1.2.1; extra == 'devel-ci'
Requires-Dist: pytest-xdist>=3.5.0; extra == 'devel-ci'
Requires-Dist: pytest>=8.2,<9; extra == 'devel-ci'
Requires-Dist: python-ldap; extra == 'devel-ci'
Requires-Dist: python3-saml>=1.16.0; extra == 'devel-ci'
Requires-Dist: requests-kerberos>=0.10.0; extra == 'devel-ci'
Requires-Dist: requests-mock>=1.11.0; extra == 'devel-ci'
Requires-Dist: requests>=2.27.0,<3; extra == 'devel-ci'
Requires-Dist: restructuredtext-lint>=1.4.0; extra == 'devel-ci'
Requires-Dist: rich-click>=1.7.0; extra == 'devel-ci'
Requires-Dist: ruff==0.5.5; extra == 'devel-ci'
Requires-Dist: s3fs>=2023.10.0; extra == 'devel-ci'
Requires-Dist: semver>=3.0.2; extra == 'devel-ci'
Requires-Dist: sentry-sdk>=1.32.0,!=1.33.0; extra == 'devel-ci'
Requires-Dist: sphinx-airflow-theme>=0.1.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx-argparse>=0.4.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx-autoapi>=3; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx-copybutton>=0.5.2; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx-design>=0.5.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx-jinja>=2.0.2; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx-rtd-theme>=2.0.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinx>=7; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-applehelp>=1.0.4; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-devhelp>=1.0.2; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-htmlhelp>=2.0.1; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-httpdomain>=1.8.1; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-jquery>=4.1; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-jsmath>=1.0.1; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-qthelp>=1.0.3; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-redoc>=1.6.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-serializinghtml>=1.1.5; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: sphinxcontrib-spelling>=8.0.0; (python_version >= "3.9") and extra == 'devel-ci'
Requires-Dist: statsd>=3.3.0; extra == 'devel-ci'
Requires-Dist: thrift-sasl>=0.2.0; extra == 'devel-ci'
Requires-Dist: time-machine>=2.13.0; extra == 'devel-ci'
Requires-Dist: towncrier>=23.11.0; extra == 'devel-ci'
Requires-Dist: twine>=4.0.2; extra == 'devel-ci'
Requires-Dist: types-aiofiles; extra == 'devel-ci'
Requires-Dist: types-certifi; extra == 'devel-ci'
Requires-Dist: types-croniter; extra == 'devel-ci'
Requires-Dist: types-deprecated; extra == 'devel-ci'
Requires-Dist: types-docutils; extra == 'devel-ci'
Requires-Dist: types-markdown; extra == 'devel-ci'
Requires-Dist: types-paramiko; extra == 'devel-ci'
Requires-Dist: types-protobuf; extra == 'devel-ci'
Requires-Dist: types-pymysql; extra == 'devel-ci'
Requires-Dist: types-python-dateutil; extra == 'devel-ci'
Requires-Dist: types-python-slugify; extra == 'devel-ci'
Requires-Dist: types-pytz; extra == 'devel-ci'
Requires-Dist: types-pyyaml; extra == 'devel-ci'
Requires-Dist: types-redis; extra == 'devel-ci'
Requires-Dist: types-requests; extra == 'devel-ci'
Requires-Dist: types-setuptools; extra == 'devel-ci'
Requires-Dist: types-tabulate; extra == 'devel-ci'
Requires-Dist: types-termcolor; extra == 'devel-ci'
Requires-Dist: types-toml; extra == 'devel-ci'
Requires-Dist: uv>=0.1.32; extra == 'devel-ci'
Requires-Dist: virtualenv; extra == 'devel-ci'
Requires-Dist: wheel>=0.42.0; extra == 'devel-ci'
Requires-Dist: yamllint>=1.33.0; extra == 'devel-ci'
Description-Content-Type: text/markdown

<!--
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements.  See the NOTICE file
distributed with this work for additional information
regarding copyright ownership.  The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License.  You may obtain a copy of the License at

  http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied.  See the License for the
specific language governing permissions and limitations
under the License.
-->

<!-- PLEASE DO NOT MODIFY THIS FILE. IT HAS BEEN GENERATED AUTOMATICALLY FROM THE `README.md` FILE OF THE
PROJECT BY THE `generate-pypi-readme` PRE-COMMIT. YOUR CHANGES HERE WILL BE AUTOMATICALLY OVERWRITTEN.-->

# Apache Airflow

[![PyPI version](https://badge.fury.io/py/apache-airflow.svg)](https://badge.fury.io/py/apache-airflow)
[![GitHub Build](https://github.com/apache/airflow/actions/workflows/ci.yml/badge.svg?branch=v2-10-test)](https://github.com/apache/airflow/actions/workflows/ci.yml?query=branch%3Av2-10-test)
[![Coverage Status](https://codecov.io/gh/apache/airflow/graph/badge.svg?token=WdLKlKHOAU)](https://codecov.io/gh/apache/airflow)
[![License](https://img.shields.io/:license-Apache%202-blue.svg)](https://www.apache.org/licenses/LICENSE-2.0.txt)
[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/apache-airflow.svg)](https://pypi.org/project/apache-airflow/)
[![Docker Pulls](https://img.shields.io/docker/pulls/apache/airflow.svg)](https://hub.docker.com/r/apache/airflow)
[![Docker Stars](https://img.shields.io/docker/stars/apache/airflow.svg)](https://hub.docker.com/r/apache/airflow)
[![PyPI - Downloads](https://img.shields.io/pypi/dm/apache-airflow)](https://pypi.org/project/apache-airflow/)
[![Artifact HUB](https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/apache-airflow)](https://artifacthub.io/packages/search?repo=apache-airflow)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Twitter Follow](https://img.shields.io/twitter/follow/ApacheAirflow.svg?style=social&label=Follow)](https://twitter.com/ApacheAirflow)
[![Slack Status](https://img.shields.io/badge/slack-join_chat-white.svg?logo=slack&style=social)](https://s.apache.org/airflow-slack)
[![Contributors](https://img.shields.io/github/contributors/apache/airflow)](https://github.com/apache/airflow/graphs/contributors)
[![OSSRank](https://shields.io/endpoint?url=https://ossrank.com/shield/6)](https://ossrank.com/p/6)

<picture width="500">
  <img
    src="https://github.com/apache/airflow/blob/19ebcac2395ef9a6b6ded3a2faa29dc960c1e635/docs/apache-airflow/img/logos/wordmark_1.png?raw=true"
    alt="Apache Airflow logo"
  />
</picture>

[Apache Airflow](https://airflow.apache.org/docs/apache-airflow/stable/) (or simply Airflow) is a platform to programmatically author, schedule, and monitor workflows.

When workflows are defined as code, they become more maintainable, versionable, testable, and collaborative.

Use Airflow to author workflows as directed acyclic graphs (DAGs) of tasks. The Airflow scheduler executes your tasks on an array of workers while following the specified dependencies. Rich command line utilities make performing complex surgeries on DAGs a snap. The rich user interface makes it easy to visualize pipelines running in production, monitor progress, and troubleshoot issues when needed.

## Requirements

Apache Airflow is tested with:

|            | Main version (dev)           | Stable version (2.11.0)      |
|------------|------------------------------|------------------------------|
| Python     | 3.9, 3.10, 3.11, 3.12        | 3.9, 3.10, 3.11, 3.12        |
| Platform   | AMD64/ARM64(\*)              | AMD64/ARM64(\*)              |
| Kubernetes | 1.26, 1.27, 1.28, 1.29, 1.30 | 1.26, 1.27, 1.28, 1.29, 1.30 |
| PostgreSQL | 12, 13, 14, 15, 16           | 12, 13, 14, 15, 16           |
| MySQL      | 8.0, 8.4, Innovation         | 8.0, Innovation              |
| SQLite     | 3.15.0+                      | 3.15.0+                      |

\* Experimental

**Note**: MariaDB is not tested/recommended.

**Note**: SQLite is used in Airflow tests. Do not use it in production. We recommend
using the latest stable version of SQLite for local development.

**Note**: Airflow currently can be run on POSIX-compliant Operating Systems. For development, it is regularly
tested on fairly modern Linux Distros and recent versions of macOS.
On Windows you can run it via WSL2 (Windows Subsystem for Linux 2) or via Linux Containers.
The work to add Windows support is tracked via [#10388](https://github.com/apache/airflow/issues/10388), but
it is not a high priority. You should only use Linux-based distros as "Production" execution environment
as this is the only environment that is supported. The only distro that is used in our CI tests and that
is used in the [Community managed DockerHub image](https://hub.docker.com/p/apache/airflow) is
`Debian Bookworm`.

## Getting started

Visit the official Airflow website documentation (latest **stable** release) for help with
[installing Airflow](https://airflow.apache.org/docs/apache-airflow/stable/installation/),
[getting started](https://airflow.apache.org/docs/apache-airflow/stable/start.html), or walking
through a more complete [tutorial](https://airflow.apache.org/docs/apache-airflow/stable/tutorial/).

> Note: If you're looking for documentation for the main branch (latest development branch): you can find it on [s.apache.org/airflow-docs](https://s.apache.org/airflow-docs/).

For more information on Airflow Improvement Proposals (AIPs), visit
the [Airflow Wiki](https://cwiki.apache.org/confluence/display/AIRFLOW/Airflow+Improvement+Proposals).

Documentation for dependent projects like provider packages, Docker image, Helm Chart, you'll find it in [the documentation index](https://airflow.apache.org/docs/).

## Installing from PyPI

We publish Apache Airflow as `apache-airflow` package in PyPI. Installing it however might be sometimes tricky
because Airflow is a bit of both a library and application. Libraries usually keep their dependencies open, and
applications usually pin them, but we should do neither and both simultaneously. We decided to keep
our dependencies as open as possible (in `pyproject.toml`) so users can install different versions of libraries
if needed. This means that `pip install apache-airflow` will not work from time to time or will
produce unusable Airflow installation.

To have repeatable installation, however, we keep a set of "known-to-be-working" constraint
files in the orphan `constraints-main` and `constraints-2-0` branches. We keep those "known-to-be-working"
constraints files separately per major/minor Python version.
You can use them as constraint files when installing Airflow from PyPI. Note that you have to specify
correct Airflow tag/version/branch and Python versions in the URL.


1. Installing just Airflow:

> Note: Only `pip` installation is currently officially supported.

While it is possible to install Airflow with tools like [Poetry](https://python-poetry.org) or
[pip-tools](https://pypi.org/project/pip-tools), they do not share the same workflow as
`pip` - especially when it comes to constraint vs. requirements management.
Installing via `Poetry` or `pip-tools` is not currently supported.

There are known issues with ``bazel`` that might lead to circular dependencies when using it to install
Airflow. Please switch to ``pip`` if you encounter such problems. ``Bazel`` community works on fixing
the problem in `this PR <https://github.com/bazelbuild/rules_python/pull/1166>`_ so it might be that
newer versions of ``bazel`` will handle it.

If you wish to install Airflow using those tools, you should use the constraint files and convert
them to the appropriate format and workflow that your tool requires.


```bash
pip install 'apache-airflow==2.11.0' \
 --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-2.11.0/constraints-3.9.txt"
```

2. Installing with extras (i.e., postgres, google)

```bash
pip install 'apache-airflow[postgres,google]==2.8.3' \
 --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-2.11.0/constraints-3.9.txt"
```

For information on installing provider packages, check
[providers](http://airflow.apache.org/docs/apache-airflow-providers/index.html).

## Official source code

Apache Airflow is an [Apache Software Foundation](https://www.apache.org) (ASF) project,
and our official source code releases:

- Follow the [ASF Release Policy](https://www.apache.org/legal/release-policy.html)
- Can be downloaded from [the ASF Distribution Directory](https://downloads.apache.org/airflow)
- Are cryptographically signed by the release manager
- Are officially voted on by the PMC members during the
  [Release Approval Process](https://www.apache.org/legal/release-policy.html#release-approval)

Following the ASF rules, the source packages released must be sufficient for a user to build and test the
release provided they have access to the appropriate platform and tools.


## Contributing

Want to help build Apache Airflow? Check out our [contributing documentation](https://github.com/apache/airflow/blob/main/contributing-docs/README.rst).

Official Docker (container) images for Apache Airflow are described in [images](https://github.com/apache/airflow/blob/main/dev/breeze/doc/ci/02_images.md).


## Voting Policy

* Commits need a +1 vote from a committer who is not the author
* When we do AIP voting, both PMC member's and committer's `+1s` are considered a binding vote.

## Who uses Apache Airflow?

We know about around 500 organizations that are using Apache Airflow (but there are likely many more)
[in the wild](https://github.com/apache/airflow/blob/main/INTHEWILD.md).

If you use Airflow - feel free to make a PR to add your organisation to the list.


## Who maintains Apache Airflow?

Airflow is the work of the [community](https://github.com/apache/airflow/graphs/contributors),
but the [core committers/maintainers](https://people.apache.org/committers-by-project.html#airflow)
are responsible for reviewing and merging PRs as well as steering conversations around new feature requests.
If you would like to become a maintainer, please review the Apache Airflow
[committer requirements](https://github.com/apache/airflow/blob/main/COMMITTERS.rst#guidelines-to-become-an-airflow-committer).
