Deprecate/remove the ability to update a module from a URL and authorize.php

Created on 4 December 2024, about 2 months ago

Problem/Motivation

See discussion in ✨ Add Alpha level Experimental Automatic Updates module Needs work and πŸ“Œ Rename update module back to Update Status Active . I have been sure we already had an issue for this but haven't been able to find it despite at least a couple of attempts, so opening a new issue.

With package_manager, automatic updates (update manager) and project browser coming into core, we need to completely remove this functionality so it's not implemented twice in two different ways.

Tagging for product and release manager review because we need to decide whether to deprecate/warn about removal in Drupal 12, or actually remove it in a minor release. This might be a case where we want to bend things a bit and fully remove at least the pages and authorize.php if not necessarily all the supporting code, to reduce potential confusion.

Steps to reproduce

Proposed resolution

Remaining tasks

User interface changes

Introduced terminology

API changes

Data model changes

Release notes snippet

πŸ“Œ Task
Status

Active

Version

11.0 πŸ”₯

Component

update.module

Created by

πŸ‡¬πŸ‡§United Kingdom catch

Live updates comments and jobs are added and updated live.
  • Needs product manager review

    It is used to alert the product manager core committer(s) that an issue represents a significant new feature, UI change, or change to the "user experience" of Drupal, and their signoff is needed. If an issue significantly affects the usability of Drupal, use Needs usability review instead (see the governance policy draft for more information).

  • Needs release manager review

    It is used to alert the release manager core committer(s) that an issue significantly affects the overall technical debt or release timeline of Drupal, and their signoff is needed. See the governance policy draft for more information.

Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @catch
  • πŸ‡«πŸ‡·France andypost

    Deprecation may need route aliases

  • πŸ‡¬πŸ‡§United Kingdom catch

    @ressa that is very possibly the issue I was thinking of, especially given I opened it. Things would have been easier now if we'd done that at the time instead of won't fixing it.

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Hah, not sure how I never saw #2352637: Remove the UI for installing/updating modules from update module if it is not fixed in time for release β†’ until now. But that was right in the era when I was AWOL from Drupal and update.module was considered "unmaintained".

    Anyway, yes, we should finally remove all this code. For reference/context, in πŸ“Œ Remove adding an extension via a URL Fixed "we" decided to directly remove the routes and code for install-new-stuff, instead of doing a deprecation dance and moving the old plumbing into an abandoned contrib module. I personally vote we do the same here.

    It'd be lovely to know for certain we'd be replacing this with the shiny/new functionality from package_manager and update_manager/auto_updates in the same release. But even if we don't know for certain, the chances that the legacy "update manager" provided by update.module are actually still helping sites stay up to date with contrib releases are pretty small. More and more of contrib is depending on composer to manage external dependencies, which this code doesn't handle. So unless you've got just the right combo of installed modules, this feature is as likely to break your site as it is to help keep it running the most secure versions of things.

    πŸ˜‚

  • πŸ‡ΊπŸ‡ΈUnited States dww

    More accurate title, since authorize.php and the UI from update.module don't use URLs -- that was the install new code stuff that's already gone. Also, update.module handles modules and themes, fwiw.

  • πŸ‡©πŸ‡°Denmark ressa Copenhagen

    @catch: Things would have been easier now if we'd done that at the time instead of won't fixing it

    How is it the saying goes ... "hindsight is 20/20"? So many things could or should have been ... I am just grateful that Drupal exists in the first place, and that there are all these amazing, gifted people such as you, @dww, and @andypost working towards a common goal of making a great CMS. Which we are winning, by the way :) I'll add the issue as related, to connect them.

  • Pipeline finished with Failed
    about 2 months ago
    Total: 87s
    #359603
  • Pipeline finished with Failed
    about 2 months ago
    Total: 87s
    #359608
  • Pipeline finished with Failed
    about 2 months ago
    Total: 87s
    #359624
  • Pipeline finished with Failed
    about 2 months ago
    Total: 155s
    #359625
  • πŸ‡«πŸ‡·France andypost

    Great clean-up!

  • Pipeline finished with Failed
    about 2 months ago
    Total: 138s
    #359633
  • πŸ‡ΊπŸ‡ΈUnited States dww

    This is among the most satisfying MRs I've opened against core in a very long time. πŸ˜‰ This is maybe too bold. I'm immediately removing everything. No deprecations, just gone. πŸ˜‚ Current diffstat:

    47 files +2 βˆ’4963

    If we want to mark all this crap (the vast majority of which I originally wrote, so I feel okay describing it that way - no offense to anyone) deprecated and only remove it in 12.x, we'll need a whole new MR. But I wanted to see what happened with this approach for now...

  • Pipeline finished with Failed
    about 2 months ago
    Total: 584s
    #359636
  • πŸ‡ΊπŸ‡ΈUnited States nicxvan
  • Pipeline finished with Failed
    about 2 months ago
    Total: 155s
    #359654
  • πŸ‡¬πŸ‡§United Kingdom catch

    I do not really think there is an API/bc risk here as such, we could check a couple of classes against contrib search just in case, so for me this comes down to a product decision about whether we can drop the feature outright.

    Given there are only about 10,000 sites already using 11.x, it does seem very unlikely that any 11.x early-adopters would also be using this feature, so possible that literally no-one would notice.

  • πŸ‡«πŸ‡·France andypost

    Looking at changes I see no reason to provide BC and deprecations

  • Pipeline finished with Success
    about 2 months ago
    Total: 1076s
    #359662
  • πŸ‡¦πŸ‡ΊAustralia mstrelan

    There are a number of references to authorize.php that need updating

    $ grep -r "authorize.php" core
    core/lib/Drupal/Core/DrupalKernel.php:      // authorize.php, and others to auto-detect a base path.
    core/lib/Drupal/Core/Render/BareHtmlPageRendererInterface.php: * - authorize.php
    core/lib/Drupal/Core/File/file.api.php: * manager when they are redirected to the authorize.php script to authorize
    core/lib/Drupal/Core/File/file.api.php: *     the authorize.php form.
    core/lib/Drupal/Core/File/file.api.php: * @see authorize.php
    core/themes/stable9/templates/admin/authorize-report.html.twig: * Theme override for authorize.php operation report templates.
    core/themes/stable9/templates/admin/authorize-report.html.twig: * This report displays the results of an operation run via authorize.php.
    core/assets/scaffold/files/htaccess:  # Allow access to PHP files in /core (like authorize.php or install.php):
    
  • Pipeline finished with Failed
    about 2 months ago
    Total: 125s
    #359694
  • Pipeline finished with Success
    about 2 months ago
    Total: 554s
    #359697
  • πŸ‡ΊπŸ‡ΈUnited States dww

    Finally got a green pipeline. πŸ˜… Diffstat is now up to: 56 files +11 βˆ’5618. πŸŽ‰

    I'm 80% sure there are still some lingering bits of cruft sprinkled about. I need to do a more thorough job of grepping for various things. But those could be cleaned up in follow-ups if we miss them on this first attempt.

    Adding some open questions to remaining tasks:

    • Decide what to do with the administer software updates permission. It's also used for update.php (DB updates), so I think it needs to stay, but TBD.
    • Decide if we can remove lib/Drupal/Core/Archiver/* and related tests, too.

    Fleshed out UI and API changes sections.

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Whoops, hadn't seen #15 when I wrote #16. Some of those are already gone with additional commits I've pushed. I'll cleanup the others now...

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Yeah, core/lib/Drupal/Core/File/file.api.php was already fixed. Pushed a commit for 3 of the others, no question.

    I'm not totally sure we should be removing the stuff from stable9. Maybe we need a frontend framework manager to signoff on that (commit b07e3fd3)?

  • Pipeline finished with Canceled
    about 2 months ago
    Total: 585s
    #359712
  • Pipeline finished with Success
    about 2 months ago
    Total: 407s
    #359725
  • πŸ‡ΊπŸ‡ΈUnited States dww

    Heh, whoops. Looking a bit more closely at everything I deleted, it includes some of these, e.g. in the Updater* world:

      public function postInstall() {
        @trigger_error(__METHOD__ . '() is deprecated in drupal:11.1.0 and is removed from drupal:12.0.0. There is no replacement. See https://www.drupal.org/node/3461934', E_USER_DEPRECATED);
      }
    

    Should we:

    1. Scale back the scope of the removals here?
    2. Make sure this lands in 11.1.0 and update the https://www.drupal.org/node/3461934 β†’ CR to match? πŸ˜‰
    3. Other?

    Thanks,
    -Derek

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Added #19 to remaining tasks.

  • πŸ‡ΊπŸ‡ΈUnited States nicxvan

    I vote 2

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Making the title match the MR. Product and/or release managers can change it back if they disagree.

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Gonna bump this to major, since it's got big implications for auto_updates / new update_manager, Drupal CMS, and since we should strongly consider doing this before 11.1.0 final.

  • πŸ‡ΊπŸ‡ΈUnited States cmlara

    I want to see support for tar/zip installs go away and move core to composer only. I do not use update module to update sites. With that in mind, given the speed in this issue is moved I feel a need to speak up for "the other side" of this and at least put something on the record for sites that may (for whatever reason I can not understand) be using these features.

    I noted in #3285191-50: [meta] Only support Drupal core installs managed by composer β†’ I do not believe features such as this should be removed in minor releases. I suggested in April this should have been done as a deprecation in D10 for removing D11 however to my knowledge the release managers did not make it a release blocker and as such we missed the D11 window. That alone should be reason not to include this at this time.

    Going a step further, even if this proceeds to be done in the 11.x branch, the release cycle is already at RC1 for 11.1.x, this is not the time for these sort of changes where their review time will be limited (unsure if core is releasing this week or if they pushed back since RC1 was delayed a week).

    Ultimately it is a release manager decision, however from my pov, as much as I see no use for this feature set, this isn't bending things a bit, it is a significant code yank, one that we knew about and could have properly planned for rather than trying to shoe-horn in at the last minute.

  • πŸ‡¬πŸ‡§United Kingdom longwave UK

    We are already trying to squeeze too much into 11.1.0 given that we are already at rc1, so I agree with @cmlara on not committing this to 11.1.x. While this does affect Drupal CMS, given that the UI is still visible and very confusing when Automatic Updates is also installed, there is nothing stopping AU fixing that, even if that is temporary.

    We still would like to remove this before Drupal 12, given that we believe few to no users currently use this feature for reasons already explained, so it is likely that this can still land in 11.2.

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Makes sense, thanks.

    Do we want to remove the routes and deprecate all the underlying functions and classes in 11.2.x, then completely remove it all in 12.0.x? Or are you thinking we directly remove everything in 11.2.x?

    Thanks again,
    -Derek

  • πŸ‡¦πŸ‡ΊAustralia larowlan πŸ‡¦πŸ‡ΊπŸ.au GMT+10
  • πŸ‡¬πŸ‡§United Kingdom catch

    I discussed this a bit with @longwave in slack and while I originally thought it was better to commit in 11.1 (when there very few installs compared to 10.x), given we think no-one is using this anyway, even if there are more 11.x installs in six months, there might be the same number (zero!) using the feature, so it might not make a real difference in practice.

    So I think we should go ahead with a full removal even though it's bending the bc policy, because we don't think anyone uses the UI, or integrates with the APIs. An early commit to 11.2 is more likely to tell us if we're somehow wrong about that, and then we could revisit.

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Cool, thanks @catch.

    Would a release manager be willing to:

    a) Respond to comment #19 πŸ˜… - Can we really remove stuff in 11.2 that we deprecated in 11.1 for removal in 12?
    b) Make a formal decision on what's happening here.
    c) Remove the 'Needs release manager review' tag.

    ?

    Also, do we need product manager review? If so, is that effectively Gabor or Lauri at this point? Should I try to ping them via Slack?

    Thanks!
    -Derek

  • πŸ‡¬πŸ‡§United Kingdom catch

    I think if we're removing the entire capability then whether we deprecated one API method or not already is not going to matter.

    So the one question here is should we make an exception to the BC/continuous upgrade policy to remove this wholesale in 11.2, on the basis that we think noone uses it, it probably doesn't work, and that it directly conflicts with features in Drupal CMS.

    For me the answer to that is yes but will ping other committers for more +1s.

  • πŸ‡¨πŸ‡¦Canada Charlie ChX Negyesi 🍁Canada
    --- a/core/authorize.php
    +++ /dev/null
    

    The people who quietly work on removing ModuleHandler::add* love this quite a bit. Please go ahead and make our lives (much) easier, thanks.

  • πŸ‡ΊπŸ‡ΈUnited States dww

    Re #31 : Indeed, see #12 where πŸ“Œ Investigate ModuleHandler::add Active was added as related. πŸ˜‰

  • πŸ‡¨πŸ‡­Switzerland znerol

    +1 for removal.

  • The Needs Review Queue Bot β†’ tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide β†’ to find step-by-step guides for working with issues.

  • πŸ‡¬πŸ‡§United Kingdom longwave UK

    I was about to post that I think we can and should remove all this without deprecation, but after spending a long time in GitLab search without finding anything useful except duplicate copies of core, I did spot that Ludwig β†’ uses some of the FileTransfer classes, and the module has 11,000 users so I'm not sure we can just drop all of this.

    In terms of the UI we believe that nobody is using these features; we don't get any bug reports or support requests about them that I have seen. We do still have users that update without Composer - I see them in the issue queue from time to time - but they still don't use this UI.

    Perhaps we can split this into two issues? One to decide what to do about the strictly UI related parts - either we disable a lot of it and add deprecation notices, or outright remove it - and a followup where we deprecate FileTransfer and some of the related parts?

  • πŸ‡¬πŸ‡§United Kingdom catch

    Splitting into two seems like a good idea. If Ludwig doesn't use any of the routes etc. , I think we could still remove those, and those are the confusing parts.

  • πŸ‡«πŸ‡·France andypost

    Ludwig already mentioning that it should be replaced, so asked how to backport route in #3377094-17: Retire Ludwig? β†’

Production build 0.71.5 2024