Version 1.0.2

  • Cast count to int to improve compatibility with all database servers
  • Add missing Flarum 1.2+ requirement from last version

stryguardian this should fix the issue for you. For future reference, can you let me know what your database server and version is? There was a "mistake" in the code but it looks like MySQL didn't care about that.

    2 months later

    clarkwinkelmann

    Just to give you an update.

    I tried (clarkwinkelmann) this version now. Still the same error but this time I tried the six packages step by step.

    Those work just fine with composer require clarkwinkelmann/flarum-ext-likes-received:

    mariadb-client-10.3
    mariadb-client-core-10.3
    mariadb-common

    The error appears updating these packages:

    mariadb-server
    mariadb-server-10.3
    mariadb-server-core-10.3

    Still:
    php flarum clarkwinkelmann:likes-received:refresh
    1/446 [â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘] 0%PHP Fatal error: Uncaught Error: Call to a member function getAttributes() on null in /pathtoflarum/vendor/illuminate/database/Eloquent/Collection.php:88
    Stack trace:
    #0 /pathtoflarum/vendor/illuminate/database/Eloquent/Collection.php(111): Illuminate\Database\Eloquent\Collection->loadAggregate()
    #1 /pathtoflarum/vendor/clarkwinkelmann/flarum-ext-likes-received/src/Commands/UpdateLikesReceivedCommand.php(26): Illuminate\Database\Eloquent\Collection->loadCount()
    #2 /pathtoflarum/vendor/illuminate/database/Concerns/BuildsQueries.php(51): ClarkWinkelmann\LikesReceived\Commands\UpdateLikesReceivedCommand->ClarkWinkelmann\LikesReceived\Commands\{closure}()
    #3 /pathtoflarum/vendor/clarkwinkelmann/flarum-ext-likes-received/src/Commands/UpdateLikesReceivedCommand.php(33): Illuminate\Database\Eloquent\Builder->chunk()
    #4 /pathtoflarum/vendor/illuminate/container/BoundMethod.php(36): ClarkWinkelmann\LikesReceived\Commands\UpdateLikesReceivedCommand->handle()
    #5 /pathtoflarum/vendor/illuminate/container/Util.php(40): Illuminate\Container\BoundMethod::Illuminate\Container\{closure}()
    #6 /pathtoflarum/vendor/illuminate/container/BoundMethod.php(93): Illuminate\Container\Util::unwrapIfClosure()
    #7 /pathtoflarum/vendor/illuminate/container/BoundMethod.php(37): Illuminate\Container\BoundMethod::callBoundMethod()
    #8 /pathtoflarum/vendor/illuminate/container/Container.php(653): Illuminate\Container\BoundMethod::call()
    #9 /pathtoflarum/vendor/illuminate/console/Command.php(136): Illuminate\Container\Container->call()
    #10 /pathtoflarum/vendor/symfony/console/Command/Command.php(298): Illuminate\Console\Command->execute()
    #11 /pathtoflarum/vendor/illuminate/console/Command.php(121): Symfony\Component\Console\Command\Command->run()
    #12 /pathtoflarum/vendor/symfony/console/Application.php(1033): Illuminate\Console\Command->run()
    #13 /pathtoflarum/vendor/symfony/console/Application.php(299): Symfony\Component\Console\Application->doRunCommand()
    #14 /pathtoflarum/vendor/symfony/console/Application.php(171): Symfony\Component\Console\Application->doRun()
    #15 /pathtoflarum/vendor/flarum/core/src/Console/Server.php(42): Symfony\Component\Console\Application->run()
    #16 /pathtoflarum/flarum(24): Flarum\Console\Server->listen()
    #17 {main}
    thrown in /pathtoflarum/vendor/illuminate/database/Eloquent/Collection.php on line 88

    My flarum info:
    Flarum core 1.3.1
    PHP version: 8.1.7
    MySQL version: 10.3.31-MariaDB-0+deb10u1
    Loaded extensions: Core, date, libxml, openssl, pcre, zlib, filter, hash, json, pcntl, Reflection, SPL, session, standard, sodium, mysqlnd, PDO, xml, calendar, ctype, curl, dom, mbstring, FFI, fileinfo, ftp, gd, gettext, iconv, exif, mysqli, pdo_mysql, Phar, posix, readline, shmop, SimpleXML, sockets, sysvmsg, sysvsem, sysvshm, tokenizer, xmlreader, xmlwriter, xsl, zip, Zend OPcache
    +------------------------------------+---------+--------+
    | Flarum Extensions | | |
    +------------------------------------+---------+--------+
    | ID | Version | Commit |
    +------------------------------------+---------+--------+
    | flarum-flags | v1.3.0 | |
    | flarum-approval | v1.3.0 | |
    | flarum-tags | v1.3.0 | |
    | flarum-suspend | v1.3.1 | |
    | flarum-markdown | v1.3.0 | |
    | flarum-likes | v1.3.0 | |
    | afrux-forum-widgets-core | v0.1.7 | |
    | flarum-subscriptions | v1.3.1 | |
    | fof-byobu | 1.1.6 | |
    | v17development-seo | v1.8.0 | |
    | therealsujitk-gifs | v4.1.1 | |
    | sycho-move-posts | v0.1.6 | |
    | nearata-no-self-likes | v1.2.0 | |
    | justoverclock-welcomebox | 1.3.6 | |
    | justoverclock-last-post-useravatar | 0.1.8 | |
    | justoverclock-events-countdown | 0.1.8 | |
    | justoverclock-country-flags | 0.2.1 | |
    | justoverclock-contactme | 0.2.3 | |
    | fof-username-request | 1.0.1 | |
    | fof-user-directory | 1.2.3 | |
    | fof-upload | 1.2.2 | |
    | fof-terms | 1.1.2 | |
    | fof-split | 1.0.1 | |
    | fof-spamblock | 1.0.2 | |
    | fof-sitemap | 1.0.3 | |
    | fof-share-social | 1.1.0 | |
    | fof-recaptcha | 1.1.0 | |
    | fof-pretty-mail | 1.0.1 | |
    | fof-polls | 1.0.5 | |
    | fof-pages | 1.0.4 | |
    | fof-nightmode | 1.3.1 | |
    | fof-merge-discussions | 1.3.0 | |
    | fof-links | 1.1.1 | |
    | fof-linguist | 1.0.4 | |
    | fof-ignore-users | 1.0.2 | |
    | fof-html-errors | 1.0.0 | |
    | fof-forum-statistics-widget | 1.0.2 | |
    | fof-formatting | 1.0.2 | |
    | fof-follow-tags | 1.1.5 | |
    | fof-drafts | 1.1.2 | |
    | fof-disposable-emails | 1.0.0 | |
    | fof-default-user-preferences | 1.0.0 | |
    | fof-cookie-consent | 1.1.0 | |
    | fof-bbcode-details | 1.0.0 | |
    | fof-ban-ips | 1.0.2 | |
    | fof-analytics | 1.0.0 | |
    | flarum-sticky | v1.3.0 | |
    | flarum-statistics | v1.3.0 | |
    | flarum-mentions | v1.3.1 | |
    | flarum-lock | v1.3.0 | |
    | flarum-lang-german | 1.3.0 | |
    | flarum-lang-french | v3.7.0 | |
    | flarum-lang-english | v1.3.0 | |
    | flarum-emoji | v1.3.0 | |
    | flarum-bbcode | v1.3.0 | |
    | darkle-fancybox | 1.1.0 | |
    | clarkwinkelmann-likes-received | 1.0.2 | |
    | clarkwinkelmann-emojionearea | 1.0.0 | |
    | clarkwinkelmann-circle-groups | 1.0.1 | |
    | askvortsov-moderator-warnings | v0.6.1 | |
    | askvortsov-categories | v3.0.6 | |
    | afrux-online-users-widget | v0.1.6 | |
    | acpl-mobile-tab | 1.1.0 | |
    +------------------------------------+---------+--------+
    Base URL: https://URL
    Installation path: /pathtoflarum
    Queue driver: sync
    Mail driver: smtp
    Debug mode: off

    What could I do?

      a year later

      clarkwinkelmann Getting the following error:
      1/41919 [â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘â–‘] 0%PHP Fatal error: Uncaught Error: Call to a member function getAttributes() on null in /www/wwwroot/domain/vendor/illuminate/database/Eloquent/Collection.php:88
      While running:
      php flarum clarkwinkelmann:likes-received:refresh

      Any help please?

        HD3D I think someone reported this error to one of my extensions in the past, not sure which. I remember it had something to do with MariaDB and some Laravel functions not working as expected. Unfortunately I never found a fix because the problem was in Laravel itself. Maybe it's something different though. Could you post your php flarum info output?

          clarkwinkelmann

          Flarum core: 1.8.1
          PHP version: 8.0.26
          MySQL version: 10.6.7-MariaDB-log
          Loaded extensions: Core, date, libxml, openssl, pcre, sqlite3, zlib, bcmath, ctype, curl, dom, fileinfo, filter, ftp, gd, gettext, hash, iconv, intl, json, mbstring, SPL, session, pcntl, standard, PDO, mysqlnd, pdo_sqlite, Phar, posix, Reflection, pdo_mysql, shmop, SimpleXML, soap, sockets, sodium, mysqli, sysvsem, tokenizer, xml, xmlreader, xmlwriter, zip, gmp
          +------------------------------------------+---------+--------+
          | Flarum Extensions                        |         |        |
          +------------------------------------------+---------+--------+
          | ID                                       | Version | Commit |
          +------------------------------------------+---------+--------+
          | flarum-flags                             | v1.8.0  |        |
          | flarum-approval                          | v1.8.0  |        |
          | flarum-suspend                           | v1.8.0  |        |
          | flarum-subscriptions                     | v1.8.0  |        |
          | flarum-tags                              | v1.8.0  |        |
          | flarum-sticky                            | v1.8.0  |        |
          | flarum-markdown                          | v1.8.0  |        |
          | fof-user-directory                       | 1.2.3   |        |
          | fof-follow-tags                          | 1.1.7   |        |
          | fof-oauth                                | 1.4.4   |        |
          | fof-byobu                                | 1.3.2   |        |
          | flarumite-simple-discussion-views        | 1.2.1   |        |
          | flarum-likes                             | v1.8.0  |        |
          | fof-merge-discussions                    | 1.4.1   |        |
          | afrux-forum-widgets-core                 | v0.1.7  |        |
          | zerosonesfun-direct-links                | 3.1     |        |
          | zerosonesfun-composer-preview            | 1.3     |        |
          | the-turk-stickiest                       | 3.0.1   |        |
          | the-turk-miserable-users                 | 1.0.2   |        |
          | the-turk-diff                            | 1.1.2   |        |
          | serakoi-flarumstaffbadge                 | 1.2.1   |        |
          | rob006-last-post-avatar                  | 1.2.4   |        |
          | ramesh-dada-bbcode-alerts                | 6.21    |        |
          | noriods-auto-more                        | v1.0.0  |        |
          | nearata-twofactor                        | v2.2.1  |        |
          | nearata-prevent-double-posting           | 1.1.0   |        |
          | nearata-maintenance-mode                 | 1.0.0   |        |
          | nearata-copy-code-to-clipboard           | v2.2.0  |        |
          | mickmelon-coloured-usernames             | 0.1.1   |        |
          | matteocontrini-imgur-upload              | v3.9.1  |        |
          | matteociaroni-public-suspensions         | v1.0.0  |        |
          | malago-ads                               | 0.3.2   |        |
          | justoverclock-purify                     | 0.1.7   |        |
          | justoverclock-edit-posts                 | 0.1.1   |        |
          | justoverclock-discussion-info            | 0.1.5   |        |
          | justoverclock-country-flags              | 0.2.1   |        |
          | justoverclock-auto-post-count-badge      | 0.2.0   |        |
          | jslirola-login2seeplus                   | v0.2.1  |        |
          | ianm-log-viewer                          | 0.1.1   |        |
          | ianm-follow-users                        | 1.3.1   |        |
          | glowingblue-password-strength            | 3.1.0   |        |
          | fof-user-bio                             | 1.2.1   |        |
          | fof-subscribed                           | 1.1.3   |        |
          | fof-stopforumspam                        | 1.2.3   |        |
          | fof-socialprofile                        | 1.1.5   |        |
          | fof-recaptcha                            | 1.3.0   |        |
          | fof-profile-image-crop                   | 1.1.5   |        |
          | fof-polls                                | 2.1.1   |        |
          | fof-pages                                | 1.0.7   |        |
          | fof-nightmode                            | 1.5.3   |        |
          | fof-moderator-notes                      | 1.2.0   |        |
          | fof-links                                | 1.2.0   |        |
          | fof-ignore-users                         | 1.2.0   |        |
          | fof-forum-statistics-widget              | 1.1.0   |        |
          | fof-formatting                           | 1.0.3   |        |
          | fof-drafts                               | 1.2.2   |        |
          | fof-disposable-emails                    | 1.0.0   |        |
          | fof-default-group                        | 1.1.1   |        |
          | fof-best-answer                          | 1.3.1   |        |
          | flarum-statistics                        | v1.8.0  |        |
          | flarum-mentions                          | v1.8.2  |        |
          | flarum-lock                              | v1.8.0  |        |
          | flarum-lang-english                      | v1.8.0  |        |
          | flarum-emoji                             | v1.8.0  |        |
          | flarum-bbcode                            | v1.8.0  |        |
          | datlechin-title-length                   | v0.1.1  |        |
          | datlechin-signup-button                  | v0.1.1  |        |
          | datlechin-scroll-buttons                 | v1.1.0  |        |
          | datlechin-discussion-count               | v0.1.0  |        |
          | clarkwinkelmann-username-blacklist       | 1.0.0   |        |
          | clarkwinkelmann-popular-discussion-badge | 1.1.1   |        |
          | clarkwinkelmann-no-email-notifications   | 1.0.0   |        |
          | clarkwinkelmann-mass-actions             | 1.1.2   |        |
          | clarkwinkelmann-mailing                  | 1.1.0   |        |
          | clarkwinkelmann-likes-received           | 1.0.2   |        |
          | clarkwinkelmann-group-list               | 1.0.0   |        |
          | clarkwinkelmann-emojionearea             | 1.0.0   |        |
          | clarkwinkelmann-discussion-open-position | 1.1.0   |        |
          | clarkwinkelmann-discussion-bookmarks     | 2.0.0   |        |
          | clarkwinkelmann-circle-groups            | 1.0.1   |        |
          | blomstra-user-filter                     | 0.1.4   |        |
          | blomstra-sort-order-toggle               | 0.2.0   |        |
          | blomstra-flag-duplicates                 | 0.2.0   |        |
          | askvortsov-pwa                           | v3.3.3  |        |
          | askvortsov-moderator-warnings            | v0.6.2  |        |
          | askvortsov-discussion-templates          | v0.8.3  |        |
          | afrux-news-widget                        | v0.1.1  |        |
          | acpl-mobile-tab                          | 1.1.1   |        |
          | acpl-lscache                             | v2.2.0  |        |
          +------------------------------------------+---------+--------+
          
          Queue driver: redis
          Session driver: redis (Code override. Configured to file)
          Scheduler status: Inactive
          Mail driver: mail
          Debug mode: off

            clarkwinkelmann

            Could be me who reported it.
            I deinstalled the extension and built a script editing a post inside a discussion instead.

            HD3D unfortunately I won't be able to look into this before 1-2 weeks, but I hope to find a workaround. While I don't use MariaDB myself I want to support it whenever possible

              a year later

              HD3D Flarum doesn't really have a way to choose the order. Extensions can specify a priority. All elements with identical priority will be ordered according to the extension loading order, which is defined by the extension dependency resolver which usually matches closely with the order the extensions were enabled in.

              So you can try to disable and re-enable extensions in a different order, or directly edit the enabled_extensions value in the database.

              If you want to guarantee a specific order even when extensions get updated or replaced, you would have to use the javascript API from a custom extension to manually set a priority on specific elements.

                clarkwinkelmann Strange that I installed Best answers and Follow users years ago but installed Sorts for User Directory a few weeks ago and it made it's place before them.

                clarkwinkelmann you can try to disable and re-enable extensions in a different order

                That didn't work though

                You mean in extensions_enabled ?
                How do I do that through phpmyadmin?

                That's my extensions_enabled
                ["flarum-flags","flarum-tags","flarum-approval","flarum-suspend","flarum-mentions","flarum-subscriptions","flarum-sticky","flarum-markdown","afrux-forum-widgets-core","fof-user-directory","fof-follow-tags","ianm-twofactor","fof-oauth","fof-byobu","flarumite-simple-discussion-views","flarum-likes","the-turk-stickiest","the-turk-miserable-users","the-turk-diff","sycho-private-facade","swaggymacro-only-starter","serakoi-flarumstaffbadge","rob006-last-post-avatar","ramesh-dada-bbcode-alerts","nearata-related-discussions","nearata-prevent-double-posting","nearata-maintenance-mode","nearata-copy-code-to-clipboard","mickmelon-coloured-usernames","matteocontrini-imgur-upload","matteociaroni-public-suspensions","malago-ads","luceos-minis","katosdev-automore","justoverclock-welcomebox","justoverclock-staff-members-widget","justoverclock-purify","justoverclock-feedback","justoverclock-edit-posts","justoverclock-discussion-info","justoverclock-country-flags","justoverclock-auto-post-count-badge","ianm-follow-users","glowingblue-password-strength","foskym-sorts-for-user-directory","fof-username-request","fof-user-bio","fof-subscribed","fof-socialprofile","fof-recaptcha","fof-profile-image-crop","fof-polls","fof-pages","fof-nightmode","fof-moderator-notes","fof-merge-discussions","fof-links","fof-linguist","fof-ignore-users","fof-forum-statistics-widget","fof-formatting","fof-filter","fof-drafts","fof-disposable-emails","fof-best-answer","fof-anti-spam","flarum-statistics","flarum-lock","flarum-lang-english","flarum-emoji","flarum-bbcode","dhtml-composer","datlechin-title-length","datlechin-signup-button","datlechin-scroll-buttons","clarkwinkelmann-username-blacklist","clarkwinkelmann-popular-discussion-badge","clarkwinkelmann-no-email-notifications","clarkwinkelmann-mass-actions","clarkwinkelmann-mailing","clarkwinkelmann-likes-received","clarkwinkelmann-group-list","clarkwinkelmann-emojionearea","clarkwinkelmann-discussion-open-position","clarkwinkelmann-discussion-bookmarks","clarkwinkelmann-circle-groups","blomstra-usercard-stats","blomstra-user-filter","blomstra-sort-order-toggle","askvortsov-pwa","askvortsov-moderator-warnings","askvortsov-discussion-templates","afrux-news-widget","acpl-mobile-tab","acpl-lscache"]

                HD3D

                If you enjoy cheese, you could use some cheesy CSS work around like for e.g.

                li.item-likesReceived {
                    float: left;
                }

                Might need tweaking for smaller devices