Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can't run DB upgrades - permission error #195

Open
kenahoo opened this issue Jun 2, 2024 · 2 comments
Open

Can't run DB upgrades - permission error #195

kenahoo opened this issue Jun 2, 2024 · 2 comments

Comments

@kenahoo
Copy link

kenahoo commented Jun 2, 2024

I originally asked this as a question at Stack Overflow: https://civicrm.stackexchange.com/questions/48137/upgrade-5-66-0-5-66-2-fails-with-permission-error .

I'm using CiviCRM with Wordpress 6.5.3 and MySQL 5.7.44.

I'm attempting to upgrade my CiviCRM from 5.66.0 to 5.66.2. When I get to the DB upgrade stage, when I hit /wp-admin/admin.php?page=CiviCRM&q=civicrm/upgrade&reset=1 -> Upgrade Now -> OK, I just see an empty progress bar and the message [Executed: undefined].

If I switch to the command-line cv (version v0.3.48), and turn on maximum debugging output, I see this:

singersin@s483:~/www/wp$ cv upgrade:db -vvv

Box Requirements Checker
========================

> Using PHP 8.1.28
> PHP is using the following php.ini file:
  /home/singersin/www/wp/php.ini

> Checking Box requirements:
  ✔ The application requires a version matching ">=7.3.0".
  ✔ The application requires the extension "json".
  ✔ The package "psy/psysh" requires the extension "json".
  ✔ The package "nikic/php-parser" requires the extension "tokenizer".
  ✔ The package "psy/psysh" requires the extension "tokenizer".
  
                                                                                                                                                                                                                      
 [OK] Your system is ready to run the application.                                                                                                                                                                    
                                                                                                                                                                                                                      

[BootTrait:debug] Start
[BootTrait:debug] Attempting to set verbose error reporting
[BootTrait:debug] Call standard cv bootstrap
[Bootstrap:debug] Options: {
    "dynamicSettingsFile": "phar:///home/singersin/private/bin/cv/lib/settings_location.php",
    "env": "CIVICRM_SETTINGS",
    "prefetch": true,
    "settingsFile": null,
    "search": true,
    "cmsType": null,
    "httpHost": "",
    "output": {}
}
[Bootstrap:debug] Find settings file
[Bootstrap:debug] Load supplemental configuration for "/home/singersin/www/wp/wp-content/uploads/civicrm/civicrm.settings.php"
[Bootstrap:notice] Find CMS root for "/home/singersin/www/wp"
[Bootstrap:notice] Found "wp" in "/home/singersin/www/wp"
[Bootstrap:notice] Simulate web environment in CLI
[Bootstrap:debug] Load settings file "/home/singersin/www/wp/wp-content/uploads/civicrm/civicrm.settings.php"
[Bootstrap:notice] Initialize class loader
[Bootstrap:notice] Call core bootstrap
[Bootstrap:debug] Finished
[BootTrait:debug] Call core bootstrap
[BootTrait:debug] Call CMS bootstrap
[BootTrait:debug] Set active MySQL timezone
[BootTrait:debug] Finished
[PHP Warning] mkdir(): Permission denied at phar:///home/singersin/private/bin/cv/src/Command/UpgradeDbCommand.php:137

In UpgradeDbCommand.php line 138:
                                                                         
  [RuntimeException]                                                     
  Failed to initialize upgrade data folder: /home/singersin/.cv/upgrade  
                                                                         

Exception trace:
  at phar:///home/singersin/private/bin/cv/src/Command/UpgradeDbCommand.php:138
 Civi\Cv\Command\UpgradeDbCommand->getUpgradeFile() at phar:///home/singersin/private/bin/cv/src/Command/UpgradeDbCommand.php:47
 Civi\Cv\Command\UpgradeDbCommand->execute() at phar:///home/singersin/private/bin/cv/vendor/symfony/console/Command/Command.php:127
 Cvphar\Symfony\Component\Console\Command\Command->run() at phar:///home/singersin/private/bin/cv/vendor/symfony/console/Application.php:637
 Cvphar\Symfony\Component\Console\Application->doRunCommand() at phar:///home/singersin/private/bin/cv/vendor/symfony/console/Application.php:190
 Cvphar\Symfony\Component\Console\Application->doRun() at phar:///home/singersin/private/bin/cv/src/Application.php:67
 Civi\Cv\Application->doRun() at phar:///home/singersin/private/bin/cv/vendor/symfony/console/Application.php:101
 Cvphar\Symfony\Component\Console\Application->run() at phar:///home/singersin/private/bin/cv/src/Application.php:33
 Civi\Cv\Application::main() at phar:///home/singersin/private/bin/cv/bin/cv:28
 require() at /home/singersin/private/bin/cv:14

I'm assuming this is because I don't have permission to create directories in $HOME (the site's hosting provider doesn't allow it):

$ ls -ld ~
drwxr-x---+ 15 root singersin 4096 Mar  9  2020 /home/singersin

Can I specify a different temporary directory for it to perform its work somehow? Trying HOME=$HOME/private/tmp cv upgrade:db didn't work, it still tried to create .cv/upgrade in the original non-writeable location. This seems to be because PHP in general doesn't allow overriding HOME:

$ HOME=foo BAR=baz php -r '$home=getenv("HOME"); $bar=getenv("BAR"); echo("[$home;$bar]\n");'
[/home/singersin;baz]

CGI binaries will let me override HOME, but cv refuses to run from a CGI binary:

$ HOME=$HOME/private/tmp php81.cgi bin/cv
Content-type: text/html


The application may only be invoked from a command line, got "cgi-fcgi"

I'm also wondering if there's some place I can find the DB update steps and just run them manually, is that an option? How can I find those SQL statements?

@joseltorres
Copy link

Short term "fix"... https://civicrm.stackexchange.com/a/49110/2946

@totten
Copy link
Member

totten commented Jan 21, 2025

FWIW, https://specifications.freedesktop.org/basedir-spec/latest/ is a common specification for where applications should put files like this.

It would seem like a tidy fix to put getenv('XDG_RUNTIME_DIR') or getenv('XDG_STATE_HOME') as higher precedence (before HOME or USERPROFILE).

(That doesn't guarantee that every system with read-only HOME will work automatically -- e.g. your env might not have XDG_* vars set. But at least those vars are shared with other applications. So setting an XDG_* var can fix things for cv and for other apps.)

--

Edit: To clarify, with an env-var like XDG_STATE_HOME, your system might already define the variable. If not, then you can define manually, as in one of these:

export XDG_STATE_HOME=/home/myuser/writablefolder
export XDG_STATE_HOME=/tmp/my-user-data
export XDG_STATE_HOME=/var/tmp/my-user-date

Then cv would put its upgrade-file under one of those folders.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants