Long story short: I screwed up an import from phpBB. Well okay, that’s not the full story.
The import itself worked flawlessly!
And at this point let me shout out to the whole team for creating an awesome piece of software (from a users point of view, an admins point of view and a devs point of view)!
But…
… I wanted to be on the safe side and edited every users email in the sql file from phpBB. So Discourse won’t send out any mails after the import, because we needed some time to restructrue posts and categories after the import. Please, don’t ask why and how.
After we finished all refurbishing tasks we wanted to edit the users emails back to their original one, only to find out admins can’t edit emails. We ended up impersonating every user and changing their email address back… only to find out the activation link may only be valid for a few (?) hours.
At least we now have users who click the link they received, but Discourse doesn’t change their address.
Luckily I didn’t screw up THAT bad. When editing the users mail in the first place, before the import, I just appended kinda nonce to the @-sign, so the domain is invalid. This means the original data is still there.
My plan is to replace the nonce with an empty string on the database. And that’s where I need help, as I have zero experience with Ruby/Rails.
I already found
And that’s quite a good start, but I need further help here.
What I think I need to to - in pseudocode:
./launcher enter app
rails c
User.where("email contains nonce").update_all(replace nonce with empty string)
Or even
User.update_all(replace nonce with empty string in email field)
As the nonce is really just some gibberish behind the @-sign, but the same gibberish for every user. And the ones I already corrected manually won’t be affected by this.
I don’t have a clue what I’m supposed to write in between the parantheses. Or if this (a replace) is even possible.