I’ve hit an issue with Lemmy. Initial startup was fine… I created my admin user and logged in. Then I created this account.

Third account I went to test with failed to login… then my other accounts also failed, so I rebooted.

Now when I try to log into my admin account, it just spins forever. Checking logs, I see this:

lemmy_server::api_routes_websocket: email_not_verified: email_not_verified

Can anyone tell me how I can manually flag my admin account as having been email verified already?

    • Lodion 🇦🇺@lemmy.clickOP
      link
      fedilink
      English
      arrow-up
      3
      ·
      edit-2
      2 years ago

      Ok, figured it out myself. For anyone else that needs it…

      Run a shell within the postgres docker container:

      docker exec -it <sitename>_postgres_1 sh

      Connect to the postgres service:

      psql -U lemmy -h 127.0.0.1 -p 5432 -d lemmy

      Connect to the lemmy database:

      \c lemmy

      Then the user table: \d local_user

      Find the user ID of the account you want to manually toggle, probably #1:

      SELECT * from local_user;

      Then update the email_verified and _accepted_application flag on the first account:

      UPDATE local_user SET email_verified = ‘t’, accepted_application = ‘t’ WHERE id = 1;

      lemmy=# UPDATE local_user SET email_verified = ‘t’, accepted_application = ‘t’ WHERE id = 3; UPDATE 1 lemmy=# UPDATE local_user SET email_verified = ‘t’, email_verified= ‘t’ WHERE id = 3; UPDATE 1 lemmy=#

      • Chris A Moody@thediscussion.site
        link
        fedilink
        English
        arrow-up
        1
        ·
        2 years ago

        Thanks for this breakdown, I seem to be having issues with the update statements: lemmy=# UPDATE local_user SET email_verified = ‘t’, accepted_application = ‘t’ WHERE id = 1; ERROR: column "‘t’" does not exist LINE 1: UPDATE local_user SET email_verified = ‘t’, accepted_applica... ^ HINT: Perhaps you meant to reference the column "local_user.id". lemmy=# UPDATE local_user SET email_verified =‘t’, accepted_application = ‘t’ WHERE id = 1; ERROR: column "‘t’" does not exist LINE 1: UPDATE local_user SET email_verified =‘t’, accepted_applicat... ^ HINT: Perhaps you meant to reference the column "local_user.id". lemmy=# UPDATE local_user SET email_verified = ‘t’, accepted_application = ‘t’ WHERE id = 3; UPDATE 1 ERROR: column "‘t’" does not exist LINE 1: UPDATE local_user SET email_verified = ‘t’, accepted_applica... ^ HINT: Perhaps you meant to reference the column "local_user.id". lemmy-#

        • prothy
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          2 years ago

          It seems that the query that Lodion shared has the wrong single quote character, rather than '. Try using it with the latter, I had the same issue as you and this was what fixed it.

        • Lodion 🇦🇺@lemmy.clickOP
          link
          fedilink
          English
          arrow-up
          1
          ·
          2 years ago

          Sorry Chris, I was figuring that out as I went. It looks like a postgres syntax error but the command matches what I used.

          If you run “SELECT * from local_user;” do you get output showing your list of registered users? Perhaps you’re not attached to the lemmy database?

            • Lodion 🇦🇺@lemmy.clickOP
              link
              fedilink
              English
              arrow-up
              1
              ·
              2 years ago

              Not sure what to suggest, sorry I’m not a DBA :(

              To make it clear, here is the command I ran enclosed with "

              “UPDATE local_user SET email_verified = ‘t’, accepted_application = ‘t’ WHERE id = 1;”

              • Chris A Moody@thediscussion.site
                link
                fedilink
                English
                arrow-up
                1
                ·
                2 years ago

                “lemmy=# UPDATE local_user SET email_verified = ‘t’, accepted_application = ‘t’ WHERE id = 1; ERROR: column “‘t’” does not exist LINE 1: UPDATE local_user SET email_verified = ‘t’, accepted_applica… ^ HINT: Perhaps you meant to reference the column “local_user.id”.” This was its response.

                • Lodion 🇦🇺@lemmy.clickOP
                  link
                  fedilink
                  English
                  arrow-up
                  1
                  ·
                  edit-2
                  2 years ago

                  I’ve just taken a look at your instance… you’re running a slightly older version. I’m guessing the DB schema has changed.

                  Does “SELECT * from local_user.id;” get you a list of users? You may need to update the other references to match whatever the old DB schema is.