Hey there - great stuff with the plugin - just installed using composer and got warnings about "abandoned packages" ? should i be concerned?

`Using version 0.1.1 for fof/recaptcha
./composer.json has been updated
Loading composer repositories with package information
Updating dependencies (including require-dev)
Package operations: 2 installs, 0 updates, 0 removals
As there is no 'unzip' command installed zip files are being unpacked using the PHP zip extension.
This may cause invalid reports of corrupted archives. Besides, any UNIX permissions (e.g. executable) defined in the archives will be lost.
Installing 'unzip' may remediate them.

  • Installing google/recaptcha (1.2.3): Downloading (100%)
  • Installing fof/recaptcha (0.1.1): Downloading (100%)

    Package s9e/flarum-ext-mediaembed is abandoned, you should avoid using it. Use fof/formatting instead.
    Package zendframework/zend-diactoros is abandoned, you should avoid using it. Use laminas/laminas-diactoros instead.
    Package zendframework/zend-escaper is abandoned, you should avoid using it. Use laminas/laminas-escaper instead.
    Package zendframework/zend-httphandlerrunner is abandoned, you should avoid using it. Use laminas/laminas-httphandlerrunner instead.
    Package zendframework/zend-stratigility is abandoned, you should avoid using it. Use laminas/laminas-stratigility instead.``

    datitisev thanks datitisev - so the packages arn't dependancies of your package then? is that just composer alerting me to other out of date packages?

      MartinJD that's correct. Composer warnings are usually based on everything you have currently installed, not only the extension you are currently adding or updating.

      In this case the zendframeworks warnings come from Flarum core itself. We will update them in the next version.

      If you see an extension name being reported as abandoned however, you might want to take action as this one was probably manually installed by yourself 😉 There's rarely a security risk, but if it's abandoned it usually means it no longer works with the latest Flarum version and could break things if enabled.

        a month later
        • [deleted]

        ValiantShishu The issue here is that ReCAPTCHA requires loading external libraries, and isn't exactly privacy orientated by default. I think a hidden input or checkbox on a form with validation - for example, if it's been filled in by a BOT, we discard the request - is a much better way to go, and it is also native in the sense that we leverage the existing libraries rather than include even more.

          [deleted] while I agree with you, it's not really relevant to the situation. The whole purpose of this extension is to add reCAPTCHA, so it's legitimate to want the latest technology available.

          ValiantShishu We already support invisible recaptchas. I thought it was V3, am I missing something ?

            clarkwinkelmann I actively use v3 on my forum with this extension and I have not run into any issues. The difference between v2 and v3 through is that v2 uses a challenge based system, where as v3 uses a score. I'm not sure how this extension checks the score or challenge.

              clarkwinkelmann tankerkiller125 This extension does not support reCAPTCHA v3. It supports standard & invisible captchas, but as v3 is based on score, that is much harder to implement.

              reCAPTCHA v3 also means the code must be loaded in every page, not just when opening the login modal - making Flarum loading times worse.

              20 days later

              Doesn't seem to work on Beta 0.12:

              ReflectionException thrown with message "Class FoF\ReCaptcha\Content\AddRecaptchaJs does not exist"

              Stacktrace:
              #54 ReflectionException in /mypath/vendor/illuminate/container/Container.php:779
              #53 ReflectionClass:__construct in /mypath/vendor/illuminate/container/Container.php:779
              #52 Illuminate\Container\Container:build in /mypath/vendor/illuminate/container/Container.php:658
              #51 Illuminate\Container\Container:resolve in /mypath/vendor/illuminate/container/Container.php:609
              #50 Illuminate\Container\Container:make in /mypath/vendor/flarum/core/src/Foundation/Application.php:521
              #49 Flarum\Foundation\Application:make in /mypath/vendor/flarum/core/src/Extend/Frontend.php:174
              #48 Flarum\Extend\Frontend:Flarum\Extend{closure} in /mypath/vendor/illuminate/container/Container.php:1069
              #47 Illuminate\Container\Container:fireCallbackArray in /mypath/vendor/illuminate/container/Container.php:1015
              #46 Illuminate\Container\Container:fireResolvingCallbacks in /mypath/vendor/illuminate/container/Container.php:677
              #45 Illuminate\Container\Container:resolve in /mypath/vendor/illuminate/container/Container.php:609
              #44 Illuminate\Container\Container:make in /mypath/vendor/flarum/core/src/Foundation/Application.php:521
              #43 Flarum\Foundation\Application:make in /mypath/vendor/flarum/core/src/Http/RouteHandlerFactory.php:49
              #42 Flarum\Http\RouteHandlerFactory:Flarum\Http{closure} in /mypath/vendor/illuminate/container/BoundMethod.php:29
              #41 call_user_func_array in /mypath/vendor/illuminate/container/BoundMethod.php:29
              #40 Illuminate\Container\BoundMethod:Illuminate\Container{closure} in /mypath/vendor/illuminate/container/BoundMethod.php:75
              #39 Illuminate\Container\BoundMethod:callBoundMethod in /mypath/vendor/illuminate/container/BoundMethod.php:31
              #38 Illuminate\Container\BoundMethod:call in /mypath/vendor/illuminate/container/Container.php:572
              #37 Illuminate\Container\Container:call in /mypath/vendor/flarum/core/src/Http/RouteHandlerFactory.php:72
              #36 Flarum\Http\RouteHandlerFactory:resolveController in /mypath/vendor/flarum/core/src/Http/RouteHandlerFactory.php:34
              #35 Flarum\Http\RouteHandlerFactory:Flarum\Http{closure} in /mypath/vendor/flarum/core/src/Http/Middleware/DispatchRoute.php:65
              #34 Flarum\Http\Middleware\DispatchRoute:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #33 Laminas\Stratigility\Next:handle in /mypath/vendor/fof/secure-https/src/Middlewares/ContentSecurityPolicyMiddleware.php:21
              #32 FoF\SecureHttps\Middlewares\ContentSecurityPolicyMiddleware:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #31 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/ShareErrorsFromSession.php:56
              #30 Flarum\Http\Middleware\ShareErrorsFromSession:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #29 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/SetLocale.php:50
              #28 Flarum\Http\Middleware\SetLocale:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #27 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/CheckCsrfToken.php:23
              #26 Flarum\Http\Middleware\CheckCsrfToken:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #25 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/AuthenticateWithSession.php:32
              #24 Flarum\Http\Middleware\AuthenticateWithSession:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #23 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/RememberFromCookie.php:51
              #22 Flarum\Http\Middleware\RememberFromCookie:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #21 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/StartSession.php:61
              #20 Flarum\Http\Middleware\StartSession:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #19 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/CollectGarbage.php:46
              #18 Flarum\Http\Middleware\CollectGarbage:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #17 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/ParseJsonBody.php:28
              #16 Flarum\Http\Middleware\ParseJsonBody:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #15 Laminas\Stratigility\Next:handle in /mypath/vendor/flarum/core/src/Http/Middleware/HandleErrors.php:57
              #14 Flarum\Http\Middleware\HandleErrors:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #13 Laminas\Stratigility\Next:handle in /mypath/vendor/laminas/laminas-stratigility/src/MiddlewarePipe.php:84
              #12 Laminas\Stratigility\MiddlewarePipe:process in /mypath/vendor/middlewares/request-handler/src/RequestHandler.php:84
              #11 Middlewares\RequestHandler:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #10 Laminas\Stratigility\Next:handle in /mypath/vendor/middlewares/base-path-router/src/BasePathRouter.php:97
              #9 Middlewares\BasePathRouter:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #8 Laminas\Stratigility\Next:handle in /mypath/vendor/laminas/laminas-stratigility/src/Middleware/OriginalMessages.php:42
              #7 Laminas\Stratigility\Middleware\OriginalMessages:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #6 Laminas\Stratigility\Next:handle in /mypath/vendor/middlewares/base-path/src/BasePath.php:53
              #5 Middlewares\BasePath:process in /mypath/vendor/laminas/laminas-stratigility/src/Next.php:61
              #4 Laminas\Stratigility\Next:handle in /mypath/vendor/laminas/laminas-stratigility/src/MiddlewarePipe.php:84
              #3 Laminas\Stratigility\MiddlewarePipe:process in /mypath/vendor/laminas/laminas-stratigility/src/MiddlewarePipe.php:73
              #2 Laminas\Stratigility\MiddlewarePipe:handle in /mypath/vendor/laminas/laminas-httphandlerrunner/src/RequestHandlerRunner.php:96
              #1 Laminas\HttpHandlerRunner\RequestHandlerRunner:run in /mypath/vendor/flarum/core/src/Http/Server.php:42
              #0 Flarum\Http\Server:listen in /mypath/public/index.php:22

                Kakifrucht Found the issue.


                0.1.2

                • Fix incorrect namespace capitalization causing issues

                Updating

                composer update fof/recaptcha
                  2 months later

                  Hello !
                  When i try to sign up, i get this error in browser console :
                  Missing required parameters: sitekey
                  Do I have to add a particular configuration somewhere ?
                  Thank you in advance :-).

                    t0t0 did you fill in the settings in the extension settings modal on the Extensions page of the admin panel ?

                    12 days later

                    @datitisev After I have pass the recaptcha click action, and fill the register information block, and then click Register button, then time out. I'm from China. Here is the debug info:

                    POST https://mysite.com/register

                    <br />
                    <b>Warning</b>: file_get_contents(https://mysite.com/recaptcha/api/siteverify): failed to open stream: Connection timed out in <b>/website/mysite.com/vendor/google/recaptcha/src/ReCaptcha/RequestMethod/Post.php</b> on line <b>80</b><br />
                    <br />
                    <b>Fatal error</b>: Uncaught Laminas\HttpHandlerRunner\Exception\EmitterException: Output has been emitted previously; cannot emit response in /website/mysite.com/vendor/laminas/laminas-httphandlerrunner/src/Exception/EmitterException.php:24
                    Stack trace:
                    #0 /website/mysite.com/vendor/laminas/laminas-httphandlerrunner/src/Emitter/SapiEmitterTrait.php(40): Laminas\HttpHandlerRunner\Exception\EmitterException::forOutputSent()
                    #1 /website/blog.mysite.com/vendor/laminas/laminas-httphandlerrunner/src/Emitter/SapiEmitter.php(27): Laminas\HttpHandlerRunner\Emitter\SapiEmitter-&gt;assertNoPreviousOutput()
                    #2 /website/blog.mysite.com/vendor/laminas/laminas-httphandlerrunner/src/RequestHandlerRunner.php(98): Laminas\HttpHandlerRunner\Emitter\SapiEmitter-&gt;emit()
                    #3 /website/blog.mysite.com/vendor/flarum/core/src/Http/Server.php(42): Laminas\HttpHandlerRunner\RequestHandlerRunner-&gt;run()
                    #4 /website/blog.mysite.com/public/index.php(26): Flarum\Http\Server-&gt;listen()
                    #5 {main}
                    thrown in <b>/website/blog.mysite.com/vendor/laminas/laminas-httphandlerrunner/src/Exception/EmitterException.php</b> on line <b>24</b><br />

                      Bredy hm, looks like some adjustments may be needed for it to work in China.

                      3 months later

                      Hi! I have 0.1.0-beta.13 installed and after I install this extension it appears in my list of extensions, but I cannot enable it (there's no checkmark). Any ideas? I'd love to have this working 🙂 Thanks!!