- Issue created by @tedbow
- 🇺🇸United States tedbow Ithaca, NY, USA
good news it looks like the new
composer audit
command is aware of drupal security status. I made a project with Drupal core 10.0.7 which is insecureRunning
composer audit --format=json
got me{ "advisories": { "drupal/core": [ { "advisoryId": "PKSA-h7d4-5mdz-2965", "packageName": "drupal/core", "affectedVersions": ">=7.0.0,<7.96|>=9.0.0,<9.4.14|>=9.5.0,<9.5.8|>=10.0.0,<10.0.8", "title": "Access bypass in Drupal core", "cve": "CVE-2023-31250", "link": "https://github.com/advisories/GHSA-8849-cv9f-vccm", "reportedAt": "2023-04-26T21:30:37+00:00", "sources": [ { "name": "GitHub", "remoteId": "GHSA-8849-cv9f-vccm" } ] } ] } }
So we could probably use this to determine if need to do updates
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
There's not enough detail yet in the issue summary for this to be completely actionable (which is why it is tagged ). Assigning to @tedbow for that. Note that there is no mention at all so far of finding non-security updates using this mechanism, i.e. bug fix releases.
composer audit
does not seem to be able to give us that.I asked @omkar.podey to go ahead and start adding at least 2 methods to
ProjectInfo
to help shape the direction, based on the title ("determine which update is available" [using a different mechanism]):- determine whether there is some update available: infer this based on the currently installed version being marked as insecure
- determine which version is the first secure version: infer this based on the version just beyond the range being marked as insecure — e.g.
>=10.0.0,<10.0.8
implies that10.0.8
is the first secure version
- Assigned to tedbow
- 🇺🇸United States tedbow Ithaca, NY, USA
I need to triage issues and figure what we need to work to finish 📌 Enable unattended updates Fixed . This issue won't block that because we don't have TUF implementation done on drupal.org yet until #3343490: Deploy rugged for TUF signing to production → . So could switch to using
composer audit
but that would not be TUF protectedActually what could happen now is an issue summary update:
- Needs to updated to reflect relying on
composer audit
would require Composer > 2.4 - Need research when Composer 2.2 is no longer support and post that on the issue
Changing to minor for now because the current actions are not urgent but once is close to be done this becomes major or critical.
- Needs to updated to reflect relying on
- Issue was unassigned.
- Assigned to omkar.podey
- Assigned to tedbow
- last update
over 1 year ago Custom Commands Failed - @omkarpodey opened merge request.
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
@omkar.podey updated the issue summary. I added one more connection.
If this is an
alpha target
, why is this marked ? - Status changed to Postponed: needs info
over 1 year ago 1:31pm 22 May 2023 - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
By the way, based on this superb comment on
composer/composer
by @mxr576,composer audit
as described above does actually not provide complete enough information? Definitely not for contrib (which is not yet a concern), but not even for core?! 😳 Not sure how to verify those statements though. - 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
Interesting prior art by @mxr756:
- https://github.com/mxr576/composer-audit-changes (MIT-licensed)
- https://github.com/mxr576/ddqg-composer-audit (MIT-licensed)
- 🇬🇧United Kingdom catch
Does this mean we should eventually refactor update status to rely on composer audit if/when that's available?
- 🇺🇸United States tedbow Ithaca, NY, USA
@catch eventually I think that would be good but there a couple complications.
- We probably don't want to make all sites that want to know about security updates enable Package Manager because it currently has system requirements base around whether the site can rewrite its own codebase(though this could might not be the web user see (#3351895)
- Running
composer audit
doesn't require rewriting the codebase so relying on Package Manager might be overkill. We could just do simpler method of calling the Composer executable and parsing the results but the site might have Composer available on the production environment.I talked with @xjm about shipping a Composer phar with core as way to be certain of the version of Composer we were using in Package Manager and she said this would not be possible(I can't remember of enough her reasoning so won't want to get it wrong here). But I assume that means we want not want to ship the phar for Update Status either
We could invoke Composer audit(probably) from the Composer php API. But that would mean we would have to add dependency on
composer/composer
which we decided not to do in 📌 [policy] Move composer/composer from a dev dependency to a production dependency Closed: won't fix
- last update
over 1 year ago Custom Commands Failed - 🇺🇸United States tedbow Ithaca, NY, USA
We can rely on Composer eventually for
composer audit
but right now this does not tell us if a version is unsupported.Drupal packagist could add this somehow
- 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
This was discussed at DrupalCon between @tedbow, myself and the Drupal Security Team. Conclusion: this should indeed become the only mechanism we use.
The Drupal Association is working on (well, @drumm is! 😄) on bringing the necessary infrastructure live.
The issue summary needs to be updated with relevant information: sequencing and infrastructure blockers.
- Issue was unassigned.
- Status changed to Postponed
over 1 year ago 3:39pm 21 June 2023 - 🇺🇸United States tedbow Ithaca, NY, USA
We can't actually commit this until ✨ Implement “list security advisories” Packagist/Composer API Fixed . It is probably not worth working to much on because it will probably be a pretty change that we would have to keep merging with 3.0.x. We should still be able to release contrib 3.0.x versions without this functionality
- 🇺🇸United States effulgentsia
Looks like at a minimum, this is postponed on ✨ Implement “list security advisories” Packagist/Composer API Fixed , so adding "PP-1" to the issue title. If this is also postponed on #3343490: Deploy rugged for TUF signing to production → and/or 📌 [PP-1] Require PHP-TUF's Composer integration plugin Postponed , then that number should be raised accordingly, but I think there's code here than can be committed ahead of those latter two issues (but not ahead of the first one), is that right?
- Assigned to tedbow
- Status changed to Postponed: needs info
over 1 year ago 10:46am 5 July 2023 - Issue was unassigned.
- Status changed to Postponed
over 1 year ago 3:23pm 5 July 2023 - 🇺🇸United States tedbow Ithaca, NY, USA
We could commit this issue before #3343490: Deploy rugged for TUF signing to production → and 📌 [PP-1] Require PHP-TUF's Composer integration plugin Postponed but it would not solve the stated problem of using TUF-protected sources.
It would basically switch from using Update XML to
composer audit
but the metadata in Composer not be TUF-protected so I am not sure it would helpful - Status changed to Needs work
over 1 year ago 8:12pm 16 August 2023 - 🇺🇸United States tedbow Ithaca, NY, USA
I think we can work on this again.
there are number of drupal.org infrastructure issues that need to be resolved for it to be committed but we should still be able to work on tests because we will always rely on mocked composer output for tests
- First commit to issue fork.
- Open on Drupal.org →Core: 10.1.x + Environment: PHP 8.1 & MySQL 8last update
about 1 year ago Not currently mergeable. - last update
about 1 year ago Custom Commands Failed - last update
about 1 year ago Custom Commands Failed - last update
about 1 year ago 670 pass, 12 fail - last update
about 1 year ago 670 pass, 12 fail - last update
about 1 year ago Custom Commands Failed - last update
about 1 year ago Custom Commands Failed - last update
about 1 year ago 450 pass, 90 fail - last update
about 1 year ago 773 pass, 2 fail - last update
about 1 year ago 756 pass, 1 fail - last update
about 1 year ago 777 pass - last update
about 1 year ago 777 pass - last update
about 1 year ago 484 pass, 88 fail - 🇺🇸United States tedbow Ithaca, NY, USA
I talked with @phenaproxima and @effulgentsia yesterday and proposed the idea of instead of altering any of the services by the update module we simply confirm the information available the drupal.org update.xml matches the same releases and secure status from Composer.
This has 2 advantages,
- Not altering the functionality of the Update module at all as far as available updates page and update emails. this is important because even though any one install this module in core experimental stage knows that they are taking some risk they might not expect it to alter the functionality of a non-experimental security focused module like the Update module
- this should probably be simpler short term solution because we can probably do all the checking of update xml release in 1 place
either in\Drupal\package_manager\ProjectInfo::getInstallableReleases
For now we could hard-code what versions of core are supported via the info in
\Drupal\update\ProjectSecurityData
combined with the releases that available of core according to composer - 🇺🇸United States tedbow Ithaca, NY, USA
I talked to @phenaproxima about this recently
We had talked about making sure that information from update XML matched what available in the ProjectInfo class basically
- Get the update XML info
- Check the info from 1 matches exactly with Composer metadata, for release and which releases are secure
The problem I realize now is that we really can't do that in
\Drupal\package_manager\ProjectInfo::getInstallableReleases()
for few reasons:- There could be time lag our processor and the update module will cache the results for the Update XML but then we call
composer info
andcomposer audit
at the time we processing the releases. So if there is new release in the last hourcomposer info
would return it and the cached update XML might not have it yet. So if we throw an exception because they don't match that will be problem \Drupal\package_manager\ProjectInfo::getProjectInfo
which is called at the beginning ofgetInstallableReleases()
is going to callupdate_calculate_project_data()
which depending on which releases are marked as supported or unpublished could mark the project itself as unpublished. So we have to do the check against composer before this pointgetProjectInfo()
andgetInstallableReleases()
both callgetAvailableProjects()
so we could check composer info there but we have the problem that for projects that are in the active codebase we rely onupdate_get_available()
but if we do that then we run into the timing problem again. That data could be hours old and a current call tocomposer info
might not match
For that reason it is probably best to compare against Composer info in
\Drupal\package_manager\PackageManagerUpdateProcessor::processFetchTask()
we should probably not rely on the Update modle process at all since this data would not be compared against composer. So this would probably mean doing 📌 Do not use the Update modules cache of UPdate XML so we can control how long it is cached Active but that should be a small change. - 🇺🇸United States drumm NY, US
The data source for advisories and insecure releases for packages.drupal.org is different from the one used for updates.drupal.org. So there will be mismatches from time to time. This may be due to human error, as both are maintained somewhat manually as advisories are published & updated.
✨ Use SA Affected Version to determine whether old versions are insecure Active could unify these, although I was hoping to wait until 7.x support was dropped, as this could only happen for modern Drupal releases.
Notably, there are a handful of unstable releases, beta & RCs, marked as insecure for update status XML as they address security issues. But there was no advisory, so packages.drupal.org does not have that data. We could remove the insecure flag from those releases, as it was never the security team’s policy.
- Status changed to Postponed: needs info
about 1 year ago 4:26pm 26 October 2023 - 🇺🇸United States tedbow Ithaca, NY, USA
Postponing this on 📌 [policy, no patch] Use Update XML in Package manager to determine release support status Active and updated 🌱 Drupal 10 Core Roadmap for Automatic Updates Active to reflect this. I just want it to very clear that the core issue blocking work on one of our last Alpha core blockers
- Status changed to Postponed
12 months ago 6:14pm 12 December 2023 - 🇬🇧United Kingdom catch
With a narrower scope, I think this would now be postponed on 📌 [policy, no patch] Use Update XML in Package manager to determine release support status Active implementing the functionality with update XML, and then a decision whether we move all that metadata to Drupal's packagist endpoint.
- 🇬🇧United Kingdom catch
Tagging for issue summary update since it would be good to document what it would entail to rely 100% on composer/d.o packagist for this information.