Update dependency distributed to v2026 [SECURITY] #1050
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
==2023.11.0→==2026.1.1GitHub Vulnerability Alerts
CVE-2026-23528
Impact
When Jupyter Lab, jupyter-server-proxy and Dask distributed are all run together it is possible to craft a URL which will result in code being executed by Jupyter due to a cross-side-scripting (XSS) bug in the Dask dashboard.
It is possible for attackers to craft a phishing URL that assumes Jupyter Lab and Dask may be running on localhost and using default ports. If a user clicks on the malicious link it will open an error page in the Dask Dashboard via the Jupyter Lab proxy which will cause code to be executed by the default Jupyter Python kernel.
In order for a user to be impacted they must be running Jupyter Lab locally on the default port (with the jupyter-server-proxy) and a Dask distributed cluster on the default port. Then they would need to click the link which would execute the malicious code.
Patches
This has been fixed in the
2026.1.1release. All users should upgrade to this version.Mitigations
There are no known workarounds for this bug. The only complete solution is to upgrade to a newer release of Dask. However, there are a few things you could do to reduce your risk.
It is possible to avoid code execution via Jupyter by uninstalling the jupyter-server-proxy and accessing the Dask dashboard directly at it's URL. However, it is still possible for an attacker to craft a URL that executes JavaScript in the user's browser in the Dask dashboard. Which is still a moderate vulnerability. Therefore we recommend all users upgrade to the latest Dask release.
Another potential mitigation is to ensure both Jupyter and the Dask dashboard are running on non-standard ports. While this doesn't resolve the problem it reduces the chance of this being exploited. If an attacker knew which ports you were using they could still craft a malicious URL, but it would require a more targeted attack.
Release Notes
dask/distributed (distributed)
v2026.1.1Compare Source
Changes
See the Changelog for more information.
v2026.1.0Compare Source
Changes
See the Changelog for more information.
v2025.12.0Compare Source
Changes
MANIFEST.in@DimitriPapadopoulos (#9149)toolzto 0.12.0 @jrbourbeau (#9151)tblibversions in CI @jacobtomlinson (#9141)See the Changelog for more information.
v2025.11.0Compare Source
Changes
pippin for docs @jrbourbeau (#9132)See the Changelog for more information.
v2025.10.0Compare Source
Changes
See the Changelog for more information.
v2025.9.1Compare Source
Changes
pynvml->nvidia-ml-pyin CI @jacobtomlinson (#9111)See the Changelog for more information.
v2025.9.0Compare Source
Changes
See the Changelog for more information.
v2025.7.0Compare Source
Changes
direct-to-workers@jrbourbeau (#9097)memrayprofiler runs on all workers @jrbourbeau (#9095)deftoclasstypo in actors docs @pfackeldey (#9091)pyarrowFileInfoimport @jrbourbeau (#9078)\_always\_use\_pickle\_for@jrbourbeau (#9086)pytestin CI to avoid coverage error @jrbourbeau (#9088)s3fsfrom testing CI environment @jrbourbeau (#9087)test\_resubmit\_nondeterministic\_task\_different\_deps@jrbourbeau (#9085)See the Changelog for more information.
v2025.5.1Compare Source
Changes
See the Changelog for more information.
v2025.5.0Compare Source
Changes
Client.mapto accept futures as args and kwargs @fjetter (#9071)filesystem-specin CI environment withfsspec@jrbourbeau (#9069)test_nannyandtest_retire_workerson linux @fjetter (#9061)See the Changelog for more information.
v2025.4.1Compare Source
Changes
See the Changelog for more information.
v2025.4.0Compare Source
Changes
worker_clientcalls @gsakkis (#9038)See the Changelog for more information.
v2025.3.0Compare Source
Changes
client.persist(collection)instead ofcollection.persist()@hendrikmakait (#9020)See the Changelog for more information.
v2025.2.0Compare Source
Changes
test_ucx::test_stresstimeout @TomAugspurger (#9002)WorkStealing.balance()@hendrikmakait (#9005)See the Changelog for more information.
v2025.1.0Compare Source
Changes
UploadDirectoryplugin to upload to scheduler @hendrikmakait (#8986)dask-exprrepo @hendrikmakait (#8978)test_serialize_scipy_sparseif usingscipy>=1.15.0@hendrikmakait (#8977)See the Changelog for more information.
v2024.12.1Compare Source
Changes
NoValidWorkerExceptionmessage @hendrikmakait (#8967)See the Changelog for more information.
v2024.12.0Compare Source
Changes
test_jupyter.py::test_shutsdown_cleanly@hendrikmakait (#8954)tornadofromconda-forgein Python 3.13 CI @jrbourbeau (#8951)See the Changelog for more information.
v2024.11.2Compare Source
Changes
See the Changelog for more information.
v2024.11.1Compare Source
Changes
See the Changelog for more information.
v2024.11.0Compare Source
Changes
stimulus_idtoSchedulerPlugin.update_graphhook @hendrikmakait (#8923)dask-exprfromdask-contribtodask@hendrikmakait (#8911)See the Changelog for more information.
v2024.10.0Compare Source
Changes
See the Changelog for more information.
v2024.9.1Compare Source
Changes
RAPIDS_VERto24.12@github-actions (#8879)Scheduler.update_graph@hendrikmakait (#8877)See the Changelog for more information.
v2024.9.0Compare Source
Changes
bokehminimum version to 3.1.0 @jrbourbeau (#8861)tokenizemodule @jrbourbeau (#8858)idempotentplugin warning @jrbourbeau (#8856)Client.mapby computingtokenonly once forfuncandkwargs@fjetter (#8855)See the Changelog for more information.
v2024.8.2Compare Source
Changes
numpy>=1.24andpyarrow>=14.0.1minimum versions @jrbourbeau (#8837)cloudpickleto 3 @jrbourbeau (#8836)See the Changelog for more information.
v2024.8.1Compare Source
Changes
RAPIDS_VERto24.10@github-actions (#8786)RuntimeError: dictionary changed size during iterationinServer._shift_counters()@hendrikmakait (#8828)worker\_clientevent @jrbourbeau (#8819)See the Changelog for more information.
v2024.8.0Compare Source
Changes
no-workers-timeout@hendrikmakait (#8806)NannyPlugin.setupandNannyPlugin.teardown@hendrikmakait (#8811)WorkerPlugin.setupandWorkerPlugin.teardown@hendrikmakait (#8810)delete_intervalandsynchronize_worker_intervalfromScheduler@hendrikmakait (#8801)dask_scheduler_workers_{added|removed}_total@hendrikmakait (#8798)worker-ttl-timeout@hendrikmakait (#8800)dask_scheduler_client_connections_{added|removed}_total@hendrikmakait (#8799)PackageInstallplugin @hendrikmakait (#8794)See the Changelog for more information.
v2024.7.1Compare Source
Changes
setuptools \< 71@jrbourbeau (#8785)p2p-failedlog event @hendrikmakait (#8777)P2PConsistencyErrorfrom failed P2P tasks. @hendrikmakait (#8748)See the Changelog for more information.
v2024.7.0Compare Source
Changes
assert\_eqimport fromcudf@jrbourbeau (#8747)pandasto 2.0 in mindeps build @jrbourbeau (#8743)is_python_shutting_down@hendrikmakait (#8492)test_task_state_instance_are_garbage_collected@hendrikmakait (#8735)test_deadlinecaused by floating-point inaccuracy @hendrikmakait ([#&Submitting Python function which sleeps too long always fails #820Configuration
📅 Schedule: Branch creation - "" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.