bound to Pendulum 3 of course.

On Fri, Mar 29, 2024 at 10:42 AM Jarek Potiuk <ja...@potiuk.com> wrote:

> Yes. IMHO we should add retroactively warning to 2.8.1 release notes with
> comment that you can still downgrade to Pendulum 2 to get old behaviour and
> then in 2.9 release notes mention that 3.12 users are bound to Pendulum 2.
>
> J.
>
>
> On Fri, Mar 29, 2024 at 10:17 AM Bolke de Bruin <bdbr...@gmail.com> wrote:
>
>> I think it's just nice to give a heads up to users. If you want to use
>> python 3.12 you are tied to pendulum 3 and airflow 2.9+. It's our first
>> release that supports 3.12 so I think it makes sense to add the note.
>>
>> B.
>>
>> Sent from my iPhone
>>
>> > On 28 Mar 2024, at 17:07, Jarek Potiuk <ja...@potiuk.com> wrote:
>> >
>> > 
>> >>
>> >> It is as we require pendulum 3 for python 3.12 support.
>> >
>> > Not really. Pendulum 3+ is the only version that works with Python 3.12,
>> > yes, But upgrading to Pendulum 3 was not connected to Airflow 2.9.
>> >
>> > Look it up in our repo. Pendulum <4 has been added in Airflow 2.8.1 and
>> > since then we have Pendulum 3 in constraints of Airflow - which also
>> means
>> > that all Airflow versions for 2.8.1 already use Pendulum 3 when
>> installed
>> > via image, unless someone downgrades Pendulum to 2 manually (which is
>> > possible for any Python version < 3.12.
>> >
>> > While possibly we should warn people that Pendulum 3 serialization
>> changes
>> > for ISO8601, it's not really connected with the Airflow 2.9 release.
>> >
>> > J.
>> >
>> >> On Thu, Mar 28, 2024 at 4:47 PM Bolke de Bruin <bdbr...@gmail.com>
>> wrote:
>> >>
>> >> It is as we require pendulum 3 for python 3.12 support.
>> >>
>> >> Sent from my iPhone
>> >>
>> >>> On 28 Mar 2024, at 15:21, Nathan Hadfield <nathan.hadfi...@king.com>
>> >> wrote:
>> >>>
>> >>> Yes, there’s this issue (turned discussion) about it but it is not
>> >> specific to 2.9.
>> >>>
>> >>> https://github.com/apache/airflow/discussions/37037
>> >>>
>> >>> From: Bolke de Bruin <bdbr...@gmail.com>
>> >>> Date: Thursday, 28 March 2024 at 13:01
>> >>> To: dev@airflow.apache.org <dev@airflow.apache.org>
>> >>> Subject: Re: Apache Airflow 2.9.0b2 available for testing
>> >>> Pendulum 3 serializes ISO8601 slightly different (missing T) AFAIK. I
>> >> thought someone opened an issue for that (don't have it handy). Maybe
>> it is
>> >> something we should at least mention in the release notes? Sent from my
>> >> iPhone > On 28 Mar
>> >>> ZjQcmQRYFpfptBannerStart
>> >>> This Message Is From an External Sender
>> >>> This message came from outside your organization.
>> >>>
>> >>> ZjQcmQRYFpfptBannerEnd
>> >>>
>> >>> Pendulum 3 serializes ISO8601 slightly different (missing T) AFAIK. I
>> >> thought someone opened an issue for that (don't have it handy). Maybe
>> it is
>> >> something we should at least mention in the release notes?
>> >>>
>> >>>
>> >>>
>> >>> Sent from my iPhone
>> >>>
>> >>>
>> >>>
>> >>>>> On 28 Mar 2024, at 00:54, Ephraim Anierobi <
>> ephraimanier...@apache.org>
>> >> wrote:
>> >>>>
>> >>>>
>> >>>
>> >>>> Hey fellow Airflowers,
>> >>>
>> >>>>
>> >>>
>> >>>> We have cut Airflow 2.9.0b2 now that all the main features have been
>> >>>
>> >>>> included.
>> >>>
>> >>>>
>> >>>
>> >>>> This "snapshot" is intended for members of the Airflow developer
>> >> community
>> >>>
>> >>>> to test the build
>> >>>
>> >>>> and allow early testing of 2.9.0. Please test this beta and create
>> >> GitHub
>> >>>
>> >>>> issues wherever possible if you encounter bugs, (use 2.9.0b2 in the
>> >> version
>> >>>
>> >>>> dropdown filter when creating the issue).
>> >>>
>> >>>>
>> >>>
>> >>>> For clarity, this is not an official release of Apache Airflow
>> either -
>> >>>
>> >>>> that doesn't happen until we make a release candidate and then vote
>> on
>> >> that.
>> >>>
>> >>>>
>> >>>
>> >>>> Airflow 2.9.0b2 is available at:
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://dist.apache.org/repos/dist/dev/airflow/2.9.0b2/__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7f_zUkew$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/dist.apache.org/repos/dist/dev/airflow/2.9.0b2/__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7f_zUkew$
>> >>>
>> >>>
>> >>>>
>> >>>
>> >>>> *apache-airflow-2.9.0-source.tar.gz* is a source release that comes
>> with
>> >>>
>> >>>> INSTALL instructions.
>> >>>
>> >>>> *apache-airflow-2.9.0.tar.gz* is the binary Python "sdist" release.
>> >>>
>> >>>> *apache_airflow-2.9.0-py3-none-any.whl* is the binary Python wheel
>> >> "binary"
>> >>>
>> >>>> release.
>> >>>
>> >>>>
>> >>>
>> >>>> This snapshot has been pushed to PyPI too at
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://pypi.org/project/apache-airflow/2.9.0b2/__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK4p9M91Pw$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/pypi.org/project/apache-airflow/2.9.0b2/__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK4p9M91Pw$
>> >>>
>> >>>
>> >>>> and can be installed by running the following command:
>> >>>
>> >>>>
>> >>>
>> >>>> pip install 'apache-airflow==2.9.0b2'
>> >>>
>> >>>>
>> >>>
>> >>>> *Constraints files* are available at
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://github.com/apache/airflow/tree/constraints-2.9.0b2__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7E1a75CQ$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/github.com/apache/airflow/tree/constraints-2.9.0b2__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7E1a75CQ$
>> >>>
>> >>>
>> >>>>
>> >>>
>> >>>> Release Notes:
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://github.com/apache/airflow/blob/2.9.0b2/RELEASE_NOTES.rst__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK6HLhPrSA$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/github.com/apache/airflow/blob/2.9.0b2/RELEASE_NOTES.rst__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK6HLhPrSA$
>> >>>
>> >>>
>> >>>>
>> >>>
>> >>>> *Changes since 2.8.4:*
>> >>>
>> >>>>
>> >>>
>> >>>> *Significant Changes*
>> >>>
>> >>>>
>> >>>
>> >>>> *Following Listener API methods are considered stable and can be used
>> >> for
>> >>>
>> >>>> production system (were experimental feature in older Airflow
>> versions)
>> >>>
>> >>>> (#36376):*
>> >>>
>> >>>>
>> >>>
>> >>>> Lifecycle events:
>> >>>
>> >>>>
>> >>>
>> >>>> - ``on_starting``
>> >>>
>> >>>> - ``before_stopping``
>> >>>
>> >>>>
>> >>>
>> >>>> DagRun State Change Events:
>> >>>
>> >>>>
>> >>>
>> >>>> - ``on_dag_run_running``
>> >>>
>> >>>> - ``on_dag_run_success``
>> >>>
>> >>>> - ``on_dag_run_failed``
>> >>>
>> >>>>
>> >>>
>> >>>> TaskInstance State Change Events:
>> >>>
>> >>>>
>> >>>
>> >>>> - ``on_task_instance_running``
>> >>>
>> >>>> - ``on_task_instance_success``
>> >>>
>> >>>> - ``on_task_instance_failed``
>> >>>
>> >>>>
>> >>>
>> >>>> *Support for Microsoft SQL-Server for Airflow Meta Database has been
>> >>>
>> >>>> removed (#36514)*
>> >>>
>> >>>>
>> >>>
>> >>>> After `discussion <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://lists.apache.org/thread/r06j306hldg03g2my1pd4nyjxg78b3h4__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK5ggbfBpg$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/lists.apache.org/thread/r06j306hldg03g2my1pd4nyjxg78b3h4__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK5ggbfBpg$
>> >>>> `__
>> >>>
>> >>>> and a `voting process <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://lists.apache.org/thread/pgcgmhf6560k8jbsmz8nlyoxosvltph2__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK6bupIS6g$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/lists.apache.org/thread/pgcgmhf6560k8jbsmz8nlyoxosvltph2__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK6bupIS6g$
>> >>>> `__,
>> >>>
>> >>>> the Airflow's PMC and Committers have reached a resolution to no
>> longer
>> >>>
>> >>>> maintain MsSQL as a supported Database Backend.
>> >>>
>> >>>>
>> >>>
>> >>>> As of Airflow 2.9.0 support of MsSQL has been removed for Airflow
>> >> Database
>> >>>
>> >>>> Backend.
>> >>>
>> >>>>
>> >>>
>> >>>> A migration script which can help migrating the database *before*
>> >> upgrading
>> >>>
>> >>>> to Airflow 2.9.0 is available in
>> >>>
>> >>>> `airflow-mssql-migration repo on Github <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://github.com/apache/airflow-mssql-migration__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK6His75uw$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/github.com/apache/airflow-mssql-migration__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK6His75uw$
>> >>>> `_.
>> >>>
>> >>>> Note that the migration script is provided without support and
>> warranty.
>> >>>
>> >>>>
>> >>>
>> >>>> This does not affect the existing provider packages (operators and
>> >> hooks),
>> >>>
>> >>>> DAGs can still access and process data from MsSQL.
>> >>>
>> >>>>
>> >>>
>> >>>> *Dataset URIs are now validated on input (#37005)*
>> >>>
>> >>>>
>> >>>
>> >>>> Datasets must use a URI that conform to rules laid down in AIP-60,
>> and
>> >> the
>> >>>
>> >>>> value
>> >>>
>> >>>> will be automatically normalized when the DAG file is parsed. See
>> >>>
>> >>>> `documentation on Datasets <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://airflow.apache.org/docs/apache-airflow/stable/authoring-and-scheduling/datasets.html__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK41dzhXtQ$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/airflow.apache.org/docs/apache-airflow/stable/authoring-and-scheduling/datasets.html__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK41dzhXtQ$
>> >>>> `_
>> >>>
>> >>>> for
>> >>>
>> >>>> a more detailed description on the rules.
>> >>>
>> >>>>
>> >>>
>> >>>> You may need to change your Dataset identifiers if they look like a
>> URI,
>> >>>
>> >>>> but are
>> >>>
>> >>>> used in a less mainstream way, such as relying on the URI's auth
>> >> section, or
>> >>>
>> >>>> have a case-sensitive protocol name.
>> >>>
>> >>>>
>> >>>
>> >>>> *The method ``get_permitted_menu_items`` in ``BaseAuthManager`` has
>> been
>> >>>
>> >>>> renamed ``filter_permitted_menu_items`` (#37627)*
>> >>>
>> >>>>
>> >>>
>> >>>> *Add REST API actions to Audit Log events (#37734)*
>> >>>
>> >>>>
>> >>>
>> >>>> The Audit Log ``event`` name for REST API events will be prepended
>> with
>> >>>
>> >>>> ``api.`` or ``ui.``, depending on if it came from the Airflow UI or
>> >>>
>> >>>> externally.
>> >>>
>> >>>>
>> >>>
>> >>>> *Official support for Python 3.12 (#38025)*
>> >>>
>> >>>>
>> >>>
>> >>>> There are a few caveats though:
>> >>>
>> >>>>
>> >>>
>> >>>> * Pendulum2 does not support Python 3.12. For Python 3.12 you need to
>> >> use
>> >>>
>> >>>> `Pendulum 3 <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://pendulum.eustace.io/blog/announcing-pendulum-3-0-0.html__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7Epl-RUw$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/pendulum.eustace.io/blog/announcing-pendulum-3-0-0.html__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7Epl-RUw$
>> >>>> `_
>> >>>
>> >>>>
>> >>>
>> >>>> * Minimum SQLAlchemy version supported when Pandas is installed for
>> >> Python
>> >>>
>> >>>> 3.12 is ``1.4.36`` released in
>> >>>
>> >>>> April 2022. Airflow 2.9.0 increases the minimum supported version of
>> >>>
>> >>>> SQLAlchemy to ``1.4.36`` for all
>> >>>
>> >>>> Python versions.
>> >>>
>> >>>>
>> >>>
>> >>>> Not all Providers support Python 3.12. At the initial release of
>> Airflow
>> >>>
>> >>>> 2.9.0 the following providers
>> >>>
>> >>>> are released without support for Python 3.12:
>> >>>
>> >>>>
>> >>>
>> >>>> * ``apache.beam`` - pending on `Apache Beam support for 3.12 <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://github.com/apache/beam/issues/29149__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7iPXgkIw$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/github.com/apache/beam/issues/29149__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK7iPXgkIw$
>> >>>> `_
>> >>>
>> >>>> * ``papermill`` - pending on Releasing Python 3.12 compatible
>> papermill
>> >>>
>> >>>> client version
>> >>>
>> >>>>  `including this merged issue <
>> >>>
>> >>>>
>> >>
>> https://urldefense.com/v3/__https://github.com/nteract/papermill/pull/771__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK5Uidvi2A$
>> >> <
>> >>
>> https://urldefense.com/v3/__https:/github.com/nteract/papermill/pull/771__;!!Ci6f514n9QsL8ck!nDdmZt2BM4BAERowEi8OynoVSS90zEDxAT-yVVfksdVJPSKQfsZS8OWgT5yOKneeZp24s5p5IK5Uidvi2A$
>> >>>> `_
>> >>>
>> >>>>
>> >>>
>> >>>> *Prevent large string objects from being stored in the Rendered
>> Template
>> >>>
>> >>>> Fields (#38094)*
>> >>>
>> >>>>
>> >>>
>> >>>> There's now a limit to the length of data that can be stored in the
>> >>>
>> >>>> Rendered Template Fields.
>> >>>
>> >>>> The limit is set to 4096 characters. If the data exceeds this limit,
>> it
>> >>>
>> >>>> will be truncated. You can change this limit
>> >>>
>> >>>> by setting the ``[core]max_template_field_length`` configuration
>> option
>> >> in
>> >>>
>> >>>> your airflow config.
>> >>>
>> >>>>
>> >>>
>> >>>> *Change xcom table column value type to longblob for MySQL backend
>> >> (#38401)*
>> >>>
>> >>>> Xcom table column ``value`` type has changed from ``blob`` to
>> >> ``longblob``.
>> >>>
>> >>>> This will allow you to store relatively big data in Xcom but process
>> can
>> >>>
>> >>>> take a significant amount of time if you have a lot of large data
>> >> stored in
>> >>>
>> >>>> Xcom.
>> >>>
>> >>>>
>> >>>
>> >>>> To downgrade from revision: ``b4078ac230a1``, ensure that you don't
>> have
>> >>>
>> >>>> Xcom values larger than 65,535 bytes. Otherwise, you'll need to clean
>> >> those
>> >>>
>> >>>> rows or run ``airflow db clean xcom`` to clean the Xcom table.
>> >>>
>> >>>>
>> >>>
>> >>>> *New Features*
>> >>>
>> >>>> - Allow users to write dag_id and task_id in their national
>> characters,
>> >>>
>> >>>> added display name for dag / task (v2) (#38446)
>> >>>
>> >>>> - Prevent large objects from being stored in the RTIF (#38094)
>> >>>
>> >>>> - Use current time to calculate duration when end date is not
>> present.
>> >>>
>> >>>> (#38375)
>> >>>
>> >>>> - Add average duration mark line in task and dagrun duration charts.
>> >>>
>> >>>> (#38214, #38434)
>> >>>
>> >>>> - Add button to manually create dataset events (#38305)
>> >>>
>> >>>> - Add ``Matomo`` as an option for analytics_tool. (#38221)
>> >>>
>> >>>> - Experimental: Support custom weight_rule implementation to
>> calculate
>> >> the
>> >>>
>> >>>> TI priority_weight (#38222)
>> >>>
>> >>>> - Adding ability to automatically set DAG to off after X times it
>> failed
>> >>>
>> >>>> sequentially (#36935)
>> >>>
>> >>>> - Add dataset conditions to next run datasets modal (#38123)
>> >>>
>> >>>> - Add task log grouping to UI (#38021)
>> >>>
>> >>>> - Add dataset_expression to grid dag details (#38121)
>> >>>
>> >>>> - Introduce mechanism to support multiple executor configuration
>> >> (#37635)
>> >>>
>> >>>> - Add color formatting for ANSI chars in logs from task executions
>> >> (#37985)
>> >>>
>> >>>> - Add the dataset_expression as part of DagModel and DAGDetailSchema
>> >>>
>> >>>> (#37826)
>> >>>
>> >>>> - Add TaskFail entries to Gantt chart (#37918)
>> >>>
>> >>>> - Allow longer rendered_map_index (#37798)
>> >>>
>> >>>> - Inherit the run_ordering from DatasetTriggeredTimetable for
>> >>>
>> >>>> DatasetOrTimeSchedule (#37775)
>> >>>
>> >>>> - Implement AIP-60 Dataset URI formats (#37005)
>> >>>
>> >>>> - Introducing Logical Operators for dataset conditional logic
>> (#37101)
>> >>>
>> >>>> - Add post endpoint for dataset events (#37570)
>> >>>
>> >>>> - Show custom instance names for a mapped task in UI (#36797)
>> >>>
>> >>>> - Add excluded/included events to get_event_logs api (#37641)
>> >>>
>> >>>> - Add datasets to dag graph (#37604)
>> >>>
>> >>>> - Show dataset events above task/run details in grid view (#37603)
>> >>>
>> >>>> - Introduce new config variable to control whether DAG processor
>> >> outputs to
>> >>>
>> >>>> stdout (#37439)
>> >>>
>> >>>> - Make Datasets ``hashable`` (#37465)
>> >>>
>> >>>> - Add conditional logic for dataset triggering (#37016)
>> >>>
>> >>>> - Implement task duration page in react. (#35863)
>> >>>
>> >>>> - Add ``queuedEvent`` endpoint to get/delete DatasetDagRunQueue
>> (#37176)
>> >>>
>> >>>> - Support multiple XCom output in the BaseOperator (#37297)
>> >>>
>> >>>> - AIP-58: Add object storage backend for xcom (#37058)
>> >>>
>> >>>> - Introduce ``DatasetOrTimeSchedule`` (#36710)
>> >>>
>> >>>> - Add ``on_skipped_callback`` to ``BaseOperator`` (#36374)
>> >>>
>> >>>> - Allow override of hovered navbar colors (#36631)
>> >>>
>> >>>> - Create new Metrics with Tagging (#36528)
>> >>>
>> >>>> - Add support for openlineage to AFS and common.io (#36410)
>> >>>
>> >>>> - Introduce ``@task.bash`` TaskFlow decorator (#30176, #37875)
>> >>>
>> >>>> - Added functionality to automatically ingest custom airflow.cfg file
>> >> upon
>> >>>
>> >>>> startup (#36289)
>> >>>
>> >>>>
>> >>>
>> >>>> *Improvements*
>> >>>
>> >>>> - Update Confirmation Logic for Config Changes on Sensitive
>> Environments
>> >>>
>> >>>> Like Production (#38299)
>> >>>
>> >>>> - Improve datasets graph UX (#38476)
>> >>>
>> >>>> - Only show latest dataset event timestamp after last run (#38340)
>> >>>
>> >>>> - Add button to clear only failed tasks in a dagrun. (#38217)
>> >>>
>> >>>> - Delete all old dag pages and redirect to grid view (#37988)
>> >>>
>> >>>> - Check task attribute before use in sentry.add_tagging() (#37143)
>> >>>
>> >>>> - Mysql change xcom value col type for MySQL backend (#38401)
>> >>>
>> >>>> - ``ExternalPythonOperator`` use version from ``sys.version_info``
>> >> (#38377)
>> >>>
>> >>>> - Replace too broad exceptions into the Core (#38344)
>> >>>
>> >>>> - Add CLI support for bulk pause and resume of DAGs (#38265)
>> >>>
>> >>>> - Implement methods on TaskInstancePydantic and DagRunPydantic
>> (#38295,
>> >>>
>> >>>> #38302, #38303, #38297)
>> >>>
>> >>>> - Made filters bar collapsible and add a full screen toggle (#38296)
>> >>>
>> >>>> - Encrypt all trigger attributes (#38233)
>> >>>
>> >>>> - Upgrade react-table package. Use with Audit Log table (#38092)
>> >>>
>> >>>> - Show if dag page filters are active (#38080)
>> >>>
>> >>>> - Add try number to mapped instance (#38097)
>> >>>
>> >>>> - Add retries to job heartbeat (#37541)
>> >>>
>> >>>> - Add REST API events to Audit Log (#37734)
>> >>>
>> >>>> - Make current working directory as templated field in BashOperator
>> >> (#37968)
>> >>>
>> >>>> - Add calendar view to react (#37909)
>> >>>
>> >>>> - Add ``run_id`` column to log table (#37731)
>> >>>
>> >>>> - Add ``tryNumber`` to grid task instance tooltip (#37911)
>> >>>
>> >>>> - Session is not used in _do_render_template_fields (#37856)
>> >>>
>> >>>> - Improve MappedOperator property types (#37870)
>> >>>
>> >>>> - Remove provide_session decorator from TaskInstancePydantic methods
>> >>>
>> >>>> (#37853)
>> >>>
>> >>>> - Ensure the "airflow.task" logger used for TaskInstancePydantic and
>> >>>
>> >>>> TaskInstance (#37857)
>> >>>
>> >>>> - Better error message for internal api call error (#37852)
>> >>>
>> >>>> - Increase tooltip size of dag grid view (#37782) (#37805)
>> >>>
>> >>>> - Use named loggers instead of root logger (#37801)
>> >>>
>> >>>> - Add Run Duration in React (#37735)
>> >>>
>> >>>> - Avoid non-recommended usage of logging (#37792)
>> >>>
>> >>>> - Improve DateTimeTrigger typing (#37694)
>> >>>
>> >>>> - Make sure all unique run_ids render a task duration bar (#37717)
>> >>>
>> >>>> - Add Dag Audit Log to React (#37682)
>> >>>
>> >>>> - Add log event for auto pause (#38243)
>> >>>
>> >>>> - Better message for exception for templated base operator fields
>> >> (#37668)
>> >>>
>> >>>> - Clean up webserver endpoints adding to audit log (#37580)
>> >>>
>> >>>> - Filter datasets graph by dag_id (#37464)
>> >>>
>> >>>> - Use new exception type inheriting BaseException for SIGTERMs
>> (#37613)
>> >>>
>> >>>> - Refactor dataset class inheritance (#37590)
>> >>>
>> >>>> - Simplify checks for package versions (#37585)
>> >>>
>> >>>> - Filter Datasets by associated dag_ids (GET /datasets) (#37512)
>> >>>
>> >>>> - Enable "airflow tasks test" to run deferrable operator (#37542)
>> >>>
>> >>>> - Make datasets list/graph width adjustable (#37425)
>> >>>
>> >>>> - Speedup determine installed airflow version in
>> >> ``ExternalPythonOperator``
>> >>>
>> >>>> (#37409)
>> >>>
>> >>>> - Add more task details from rest api (#37394)
>> >>>
>> >>>> - Add confirmation dialog box for DAG run actions (#35393)
>> >>>
>> >>>> - Added shutdown color to the STATE_COLORS (#37295)
>> >>>
>> >>>> - Remove legacy dag details page and redirect to grid (#37232)
>> >>>
>> >>>> - Order XCom entries by map index in API (#37086)
>> >>>
>> >>>> - Add data_interval_start and data_interval_end in dagrun create API
>> >>>
>> >>>> endpoint (#36630)
>> >>>
>> >>>> - Making links in task logs as hyperlinks by preventing HTML
>> injection
>> >>>
>> >>>> (#36829)
>> >>>
>> >>>> - Improve ExternalTaskSensor Async Implementation (#36916)
>> >>>
>> >>>> - Make Datasets ``Pathlike`` (#36947)
>> >>>
>> >>>> - Simplify query for orphaned tasks (#36566)
>> >>>
>> >>>> - Add deferrable param in FileSensor (#36840)
>> >>>
>> >>>> - Run Trigger Page: Configurable number of recent configs (#36878)
>> >>>
>> >>>> - Merge ``nowait`` and skip_locked into with_row_locks (#36889)
>> >>>
>> >>>> - Return the specified field when get ``dag/dagRun`` in the REST API
>> >>>
>> >>>> (#36641)
>> >>>
>> >>>> - Only iterate over the items if debug is enabled for
>> >>>
>> >>>> DagFileProcessorManager (#36761)
>> >>>
>> >>>> - Add a fuzzy/regex pattern-matching for metric allow and block list
>> >>>
>> >>>> (#36250)
>> >>>
>> >>>> - Allow custom columns in cli dags list (#35250)
>> >>>
>> >>>> - Make it possible to change the default cron timetable (#34851)
>> >>>
>> >>>> - Some improvements to Airflow IO code (#36259)
>> >>>
>> >>>> - Improve TaskInstance typing hints (#36487)
>> >>>
>> >>>> - Remove dependency of ``Connexion`` from auth manager interface
>> >> (#36209)
>> >>>
>> >>>> - Refactor ExternalDagLink to not create ad hoc TaskInstances
>> (#36135)
>> >>>
>> >>>>
>> >>>
>> >>>> *Bug Fixes*
>> >>>
>> >>>> - Show abandoned tasks in Grid View (#38511)
>> >>>
>> >>>> - Apply task instance mutation hook consistently (#38440)
>> >>>
>> >>>> - Override ``chakra`` styles to keep ``dropdowns`` in filter bar
>> >> (#38456)
>> >>>
>> >>>> - Store duration in seconds and scale to handle case when a value in
>> the
>> >>>
>> >>>> series has a larger unit than the preceding durations. (#38374)
>> >>>
>> >>>> - Don't allow defaults other than None in context parameters, and
>> >> improve
>> >>>
>> >>>> error message (#38015)
>> >>>
>> >>>> - Make postgresql default engine args comply with SA 2.0 (#38362)
>> >>>
>> >>>> - Add return statement to yield within a while loop in triggers
>> (#38389)
>> >>>
>> >>>> - Ensure ``__exit__`` is called in decorator context managers
>> (#38383)
>> >>>
>> >>>> - Make the method ``BaseAuthManager.is_authorized_custom_view``
>> abstract
>> >>>
>> >>>> (#37915)
>> >>>
>> >>>> - Add upper limit to planned calendar events calculation (#38310)
>> >>>
>> >>>> - Fix Scheduler in daemon mode doesn't create PID at the specified
>> >> location
>> >>>
>> >>>> (#38117)
>> >>>
>> >>>> - Properly serialize TaskInstancePydantic and DagRunPydantic (#37855)
>> >>>
>> >>>> - Fix graph task state border color (#38084)
>> >>>
>> >>>> - Add back methods removed in security manager (#37997)
>> >>>
>> >>>> - Don't log "403" from worker serve-logs as "Unknown error". (#37933)
>> >>>
>> >>>> - Fix execution data validation error in ``/get_logs_with_metadata``
>> >>>
>> >>>> endpoint (#37756)
>> >>>
>> >>>> - Fix task duration selection (#37630)
>> >>>
>> >>>> - Refrain from passing ``encoding`` to the SQL engine in SQLAlchemy
>> v2
>> >>>
>> >>>> (#37545)
>> >>>
>> >>>> - Fix 'implicitly coercing SELECT object to scalar subquery' in
>> latest
>> >> dag
>> >>>
>> >>>> run statement (#37505)
>> >>>
>> >>>> - Clean up typing with max_execution_date query builder (#36958)
>> >>>
>> >>>> - Optimize max_execution_date query in single dag case (#33242)
>> >>>
>> >>>> - Fix list dags command for get_dagmodel is None (#36739)
>> >>>
>> >>>> - Load ``consuming_dags`` attr eagerly before dataset listener
>> (#36247)
>> >>>
>> >>>>
>> >>>
>> >>>> *Miscellaneous*
>> >>>
>> >>>> - Use ``importlib_metadata`` with compat to Python 3.10/3.12
>> ``stdlib``
>> >>>
>> >>>> (#38366)
>> >>>
>> >>>> - Refactored ``__new__`` magic method of BaseOperatorMeta to avoid
>> bad
>> >>>
>> >>>> mixing classic and decorated operators (#37937)
>> >>>
>> >>>> - Use ``sys.version_info`` for determine Python Major.Minor (#38372)
>> >>>
>> >>>> - Add missing deprecated Fab auth manager (#38376)
>> >>>
>> >>>> - Remove unused loop variable from airflow package (#38308)
>> >>>
>> >>>> - Adding max consecutive failed dag runs info in UI (#38229)
>> >>>
>> >>>> - Bump minimum version of ``blinker`` add where it requires (#38140)
>> >>>
>> >>>> - Bump follow-redirects from 1.15.4 to 1.15.6 in /airflow/www
>> (#38156)
>> >>>
>> >>>> - Bump Cryptography to ``> 39.0.0`` (#38112)
>> >>>
>> >>>> - Add Python 3.12 support (#36755, #38025, #36595)
>> >>>
>> >>>> - Avoid use of ``assert`` outside of the tests (#37718)
>> >>>
>> >>>> - Update ObjectStoragePath for universal_pathlib>=v0.2.2 (#37930)
>> >>>
>> >>>> - Resolve G004: Logging statement uses f-string (#37873)
>> >>>
>> >>>> - Update build and install dependencies. (#37910)
>> >>>
>> >>>> - Bump sanitize-html from 2.11.0 to 2.12.1 in /airflow/www (#37833)
>> >>>
>> >>>> - Update to latest installer versions. (#37754)
>> >>>
>> >>>> - Deprecate smtp configs in airflow settings / local_settings
>> (#37711)
>> >>>
>> >>>> - Deprecate PY* constants into the airflow module (#37575)
>> >>>
>> >>>> - Remove usage of deprecated ``flask._request_ctx_stack`` (#37522)
>> >>>
>> >>>> - Remove redundant ``login`` attribute in ``airflow.__init__.py``
>> >> (#37565)
>> >>>
>> >>>> - Upgrade to FAB 4.3.11 (#37233)
>> >>>
>> >>>> - Remove SCHEDULED_DEPS which is no longer used anywhere since 2.0.0
>> >>>
>> >>>> (#37140)
>> >>>
>> >>>> - Replace ``datetime.datetime.utcnow`` by
>> >> ``airflow.utils.timezone.utcnow``
>> >>>
>> >>>> in core (#35448)
>> >>>
>> >>>> - Bump aiohttp min version to avoid CVE-2024-23829 and CVE-2024-23334
>> >>>
>> >>>> (#37110)
>> >>>
>> >>>> - Move config related to FAB auth manager to FAB provider (#36232)
>> >>>
>> >>>> - Remove MSSQL support form Airflow core (#36514)
>> >>>
>> >>>> - Remove ``is_authorized_cluster_activity`` from auth manager
>> (#36175)
>> >>>
>> >>>> - Create FAB provider and move FAB auth manager in it (#35926)
>> >>>
>> >>>>
>> >>>
>> >>>> *Doc Only Changes*
>> >>>
>> >>>> - Removed/Updated Outdated UI screenshots from documentation (#38403,
>> >>>
>> >>>> #38438, #38435)
>> >>>
>> >>>> - Remove section as it's no longer true with dataset expressions PR
>> >> (#38370)
>> >>>
>> >>>> - Refactor DatasetOrTimeSchedule timetable docs (#37771)
>> >>>
>> >>>> - Migrate executor docs to respective providers (#37728)
>> >>>
>> >>>> - Add directive to render a list of URI schemes (#37700)
>> >>>
>> >>>> - Add doc page with providers deprecations (#37075)
>> >>>
>> >>>> - Add a cross reference to security policy (#37004)
>> >>>
>> >>>> - Improve AIRFLOW__WEBSERVER__BASE_URL docs (#37003)
>> >>>
>> >>>> - Update faq.rst with (hopefully) clearer description of start_date
>> >> (#36846)
>> >>>
>> >>>> - Update public interface doc re operators (#36767)
>> >>>
>> >>>> - Add ``exception`` to templates ref list (#36656)
>> >>>
>> >>>> - Add auth manager interface as public interface (#36312)
>> >>>
>> >>>> - Reference fab provider documentation in Airflow documentation
>> (#36310)
>> >>>
>> >>>> - Create auth manager documentation (#36211)
>> >>>
>> >>>> - Update permission docs (#36120)
>> >>>
>> >>>> - Docstring improvement to _covers_every_hour (#36081)
>> >>>
>> >>>> - Add note that task instance, dag and lifecycle listeners are
>> >>>
>> >>>> non-experimental (#36376)
>> >>>
>> >>>>
>> >>>
>> >>>> Cheers,
>> >>>
>> >>>> Ephraim
>> >>>
>> >>>
>> >>>
>> >>> ---------------------------------------------------------------------
>> >>>
>> >>> To unsubscribe, e-mail: dev-unsubscr...@airflow.apache.org
>> >>>
>> >>> For additional commands, e-mail: dev-h...@airflow.apache.org
>> >>>
>> >>>
>> >>
>> >> ---------------------------------------------------------------------
>> >> To unsubscribe, e-mail: dev-unsubscr...@airflow.apache.org
>> >> For additional commands, e-mail: dev-h...@airflow.apache.org
>> >>
>> >>
>>
>> ---------------------------------------------------------------------
>> To unsubscribe, e-mail: dev-unsubscr...@airflow.apache.org
>> For additional commands, e-mail: dev-h...@airflow.apache.org
>>
>>

Reply via email to