Skip to content

Commit

Permalink
Add Cache-Control "no-store" to all dynamically generated content (ap…
Browse files Browse the repository at this point in the history
…ache#39550)

This one prevents accidental storing of dynamic content containing
potentially sensitive data in cache. The way we implemented it, we
check if the response already contains "Cache-Control" - if it does
then it means that this is a static content with default cache
control set by SEND_FILE_MAX_AGE_DEFAULT setting (43200 by default).
  • Loading branch information
potiuk authored May 10, 2024
1 parent f219027 commit 94eb647
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 0 deletions.
2 changes: 2 additions & 0 deletions airflow/www/app.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@
from airflow.www.extensions.init_robots import init_robots
from airflow.www.extensions.init_security import (
init_api_experimental_auth,
init_cache_control,
init_check_user_active,
init_xframe_protection,
)
Expand Down Expand Up @@ -180,6 +181,7 @@ def create_app(config=None, testing=False):

init_jinja_globals(flask_app)
init_xframe_protection(flask_app)
init_cache_control(flask_app)
init_airflow_session_interface(flask_app)
init_check_user_active(flask_app)
return flask_app
Expand Down
9 changes: 9 additions & 0 deletions airflow/www/extensions/init_security.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,15 @@ def init_api_experimental_auth(app):
raise AirflowException(err)


def init_cache_control(app):
def apply_cache_control(response):
if "Cache-Control" not in response.headers:
response.headers["Cache-Control"] = "no-store"
return response

app.after_request(apply_cache_control)


def init_check_user_active(app):
@app.before_request
def check_user_active():
Expand Down

0 comments on commit 94eb647

Please sign in to comment.