• MetaBlog
  • Extension Manager Stable Release & Install Flarum Via ZIP File

One thing I finally figured out after just about getting frustrated and hope this helps others. After the recent update to the Extension Manager extension it deleted my authentication token for premium extensions on Extiverse so if your able to check for extensions but unable to install or update extensions using the Extension Manager and you have premium extensions from Extiverse installed make sure your authentication token is showing up. If not readd it and MAKE sure you hit save changes.

I was getting so frustrated with not being able to install or update using this extension I was about to just give up and just delete everything but I noticed in one of the composer outputs in the Extension Manager failed installs or updates that it mentioned about authentication and I noticed there was none. So I added it back and now I can install and update using this extension again. So if you have premium extensions installed make sure it still shows an entry under authentication cause if not you may have the same issues I did, Hope this helps someone.

Global Update appears to be downloading everything, this happened once I figured it was an oddity but two days and twice it's done exactly this - doesn't seem like this is intended.

`Loading composer repositories with package information
Updating dependencies
Lock file operations: 0 installs, 1 update, 0 removals

  • Upgrading ianm/twofactor (1.1.0 => 1.1.1)
    Writing lock file
    Installing dependencies from lock file
    Package operations: 174 installs, 0 updates, 0 removals
  • Downloading wikimedia/less.php (v3.2.1)
  • Downloading symfony/polyfill-ctype (v1.29.0)
  • Downloading symfony/deprecation-contracts (v3.4.0)
  • Downloading symfony/yaml (v5.4.35)
  • Downloading symfony/translation-contracts (v2.5.2)
  • Downloading symfony/polyfill-php80 (v1.29.0)
  • Downloading symfony/polyfill-mbstring (v1.29.0)
  • Downloading symfony/translation (v5.4.35)
  • Downloading symfony/polyfill-intl-messageformatter (v1.29.0)
  • Downloading symfony/polyfill-php72 (v1.29.0)
  • Downloading symfony/polyfill-intl-normalizer (v1.29.0)
  • Downloading symfony/polyfill-intl-idn (v1.29.0)
  • Downloading symfony/mime (v5.4.35)
  • Downloading psr/event-dispatcher (1.0.0)
  • Downloading symfony/event-dispatcher-contracts (v3.4.0)
  • Downloading symfony/event-dispatcher (v5.4.35)
  • Downloading symfony/polyfill-intl-grapheme (v1.29.0)
  • Downloading symfony/string (v6.4.3)
  • Downloading psr/container (1.1.2)
  • Downloading symfony/service-contracts (v3.4.1)
  • Downloading symfony/polyfill-php73 (v1.29.0)
  • Downloading symfony/console (v5.4.35)
  • Downloading symfony/polyfill-php81 (v1.29.0)
  • Downloading symfony/filesystem (v6.4.3)
  • Downloading symfony/config (v5.4.35)
  • Downloading axy/backtrace (2.0.0)
  • Downloading sycho/errors (3.0.0)
    [SNIPPED]
    174/174 [============================] 100%
    <warning>Package swiftmailer/swiftmailer is abandoned, you should avoid using it. Use symfony/mailer instead.</warning>
    Generating optimized autoload files
    105 packages you are using are looking for funding.
    Use the composer fund command to find out more!
    No security vulnerability advisories found.`

    RelicSystem it's intended. It downloads everything anew and then replaces the old vendor.

    This prevents a big issue with composer crashing when it downloads it's own dependencies.

      a month later

      Hello, I had an issue after installing this extension. I cannot clear the cache on the admin dashboard. Every time I save something on the admin dashboard, I get an error, but the settings are saved. Every time I enable or disable an extension in the admin dashboard, I also get an error, but when I try to refresh the page, it's done too.

      I already remove this extension manager but the issue is still there.

      This is an error when i try to clear cache on the admin dashboard.
      `XHRPOST
      https://mywebsite/api/cache
      [HTTP/3 409 Conflict 1476ms]

      POST https://mywebsite/api/cache 409 Application.tsx:602:16
      Flarum\Foundation\IOException in /www/wwwroot/mywebsite/vendor/flarum/core/src/Api/Controller/ClearCacheController.php:56
      Stack trace:
      #0 /www/wwwroot/mywebsite/vendor/flarum/core/src/Api/Controller/AbstractDeleteController.php(24): Flarum\Api\Controller\ClearCacheController->delete()
      #1 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/RouteHandlerFactory.php(41): Flarum\Api\Controller\AbstractDeleteController->handle()
      #2 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/ExecuteRoute.php(27): Flarum\Http\RouteHandlerFactory->Flarum\Http{closure}()
      #3 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\ExecuteRoute->process()
      #4 /www/wwwroot/mywebsite/vendor/flarum/core/src/Api/Middleware/ThrottleApi.php(33): Laminas\Stratigility\Next->handle()
      #5 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Api\Middleware\ThrottleApi->process()
      #6 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/CheckCsrfToken.php(44): Laminas\Stratigility\Next->handle()
      #7 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\CheckCsrfToken->process()
      #8 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/ResolveRoute.php(69): Laminas\Stratigility\Next->handle()
      #9 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\ResolveRoute->process()
      #10 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/SetLocale.php(51): Laminas\Stratigility\Next->handle()
      #11 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\SetLocale->process()
      #12 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/AuthenticateWithHeader.php(58): Laminas\Stratigility\Next->handle()
      #13 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\AuthenticateWithHeader->process()
      #14 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/AuthenticateWithSession.php(31): Laminas\Stratigility\Next->handle()
      #15 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\AuthenticateWithSession->process()
      #16 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/RememberFromCookie.php(52): Laminas\Stratigility\Next->handle()
      #17 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\RememberFromCookie->process()
      #18 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/StartSession.php(61): Laminas\Stratigility\Next->handle()
      #19 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\StartSession->process()
      #20 /www/wwwroot/mywebsite/vendor/flarum/core/src/Api/Middleware/FakeHttpMethods.php(29): Laminas\Stratigility\Next->handle()
      #21 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Api\Middleware\FakeHttpMethods->process()
      #22 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/ParseJsonBody.php(28): Laminas\Stratigility\Next->handle()
      #23 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\ParseJsonBody->process()
      #24 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/HandleErrors.php(57): Laminas\Stratigility\Next->handle()
      #25 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\HandleErrors->process()
      #26 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/InjectActorReference.php(25): Laminas\Stratigility\Next->handle()
      #27 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\InjectActorReference->process()
      #28 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/MiddlewarePipe.php(75): Laminas\Stratigility\Next->handle()
      #29 /www/wwwroot/mywebsite/vendor/middlewares/request-handler/src/RequestHandler.php(84): Laminas\Stratigility\MiddlewarePipe->process()
      #30 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Middlewares\RequestHandler->process()
      #31 /www/wwwroot/mywebsite/vendor/middlewares/base-path-router/src/BasePathRouter.php(101): Laminas\Stratigility\Next->handle()
      #32 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Middlewares\BasePathRouter->process()
      #33 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Middleware/OriginalMessages.php(36): Laminas\Stratigility\Next->handle()
      #34 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Laminas\Stratigility\Middleware\OriginalMessages->process()
      #35 /www/wwwroot/mywebsite/vendor/middlewares/base-path/src/BasePath.php(73): Laminas\Stratigility\Next->handle()
      #36 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Middlewares\BasePath->process()
      #37 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Middleware/ProcessIp.php(24): Laminas\Stratigility\Next->handle()
      #38 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/Next.php(49): Flarum\Http\Middleware\ProcessIp->process()
      #39 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/MiddlewarePipe.php(75): Laminas\Stratigility\Next->handle()
      #40 /www/wwwroot/mywebsite/vendor/laminas/laminas-stratigility/src/MiddlewarePipe.php(64): Laminas\Stratigility\MiddlewarePipe->process()
      #41 /www/wwwroot/mywebsite/vendor/laminas/laminas-httphandlerrunner/src/RequestHandlerRunner.php(96): Laminas\Stratigility\MiddlewarePipe->handle()
      #42 /www/wwwroot/mywebsite/vendor/flarum/core/src/Http/Server.php(45): Laminas\HttpHandlerRunner\RequestHandlerRunner->run()
      #43 /www/wwwroot/mywebsite/public/index.php(26): Flarum\Http\Server->listen()
      #44 {main} Application.tsx:605:23
      `

        pxnji check the Flarum log file or try running the php flarum cache:clear command from SSH.

        https://docs.flarum.org/troubleshoot

        The IOException error just means the cache clear command failed in the background. Details will only be logged to the command line or log file.

        It has likely nothing to do with the Extension Manager at all. Likely relates to filesystem permissions.

          pxnji refer to the section on the Flarum install guide in regards to ownership and permissions.

            pxnji what user runs the site as and what user owns the storage/cache directory?

              pxnji please share the exact error message found in the Flarum log file. If it's a filesystem issue, it will say which folder(s) are not configured properly. And if it's something else then the error message is the only way we will be able to help.

                luceos I found out there is a folder inside storage/cache that the user who owns it is root. So, I changed it to www, and then it's fixed.

                clarkwinkelmann Everything is fixed now.

                Thank you guys!

                2 months later

                I installed this extension after upgrading flarum to 1.8.5. When I try to turn on the extension, I can't. It goes back to "Disable"

                What happens?

                8 days later

                Installed the extension manager and it works well but when I install an extension i get the message:

                Oops! Something went wrong. Please reload the page and try again.

                But when I reload the page, the extension has installed successfully. Is there something I can do to fix this?

                  luceos

                  What am I looking for in here. I can see this mentioning extension manager:

                  #3 /vendor/flarum/extension-manager/src/Support/Util.php(68): Symfony\Component\Console\Input\ArgvInput->__toString()
                  #4 /vendor/flarum/extension-manager/src/Composer/ComposerAdapter.php(94): Flarum\ExtensionManager\Support\Util::readableConsoleInput()
                  #5 /vendor/flarum/extension-manager/src/Command/RequireExtensionHandler.php(79): Flarum\ExtensionManager\Composer\ComposerAdapter->run()

                  I can see an error at the top of the log but not sure how connected that is?
                  [2024-05-15 11:48:33] flarum.ERROR: Error: Call to undefined function Symfony\Component\Console\Input\escapeshellarg() in /vendor/symfony/console/Input/Input.php:195

                  I don't know if you need the full log file or not to see what's going on? I've just tried to install another plugin to reproduce the error and it writes another log file for today with several rows on it.

                  a month later

                  What will the authentication section be like?