Metadata-Version: 2.4 Name: apache-airflow Version: 2.10.5 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 Maintainer-email: Apache Software Foundation 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.8 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.8.1 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 # 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) Apache Airflow logo [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.10.4) | |-------------|------------------------------|------------------------------| | Python | 3.9, 3.10, 3.11, 3.12 | 3.8, 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 `_ 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.10.4' \ --constraint "https://raw.githubusercontent.com/apache/airflow/constraints-2.10.4/constraints-3.8.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.10.4/constraints-3.8.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](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).