I also reached out to them on Twitter but they directed me to this form. I followed up with them on Twitter with what happened in this screenshot but they are now ignoring me.

  • aard
    link
    fedilink
    English
    221 year ago

    I’m not aware of any correct email validations. I’m still looking for something accepting a space in the localpart.

    Also a surprising number of sites mess with the casing of the localpart. Don’t do that - many mailservers do accept arbitrary case, but not all. [email protected] and [email protected] are two different mail addresses, which may point to the same mailbox if you are lucky.

    • @CosmicTurtle
      link
      English
      251 year ago

      The only correct regex for email is: .+@.+

      So long as the address has a local part, the at sign, and a hostname, it’s a valid email address.

      Whether it goes somewhere is the tricky part.

      • @xantoxis
        link
        English
        24
        edit-2
        1 year ago

        Sorry, this is not a correct regex for an email address.

        Sending using mail on a local unix system? You only need the local part.

        STOP VALIDATING NAMES AND EMAIL ADDRESSES. Send a verification email. Full stop. Don’t do anything else. You really want to do this anyway, because it’s a defense against bots.

        • StarDreamer
          link
          fedilink
          English
          10
          edit-2
          1 year ago

          *Gasp* the registration is coming from inside the colo!

        • Turun
          link
          fedilink
          English
          51 year ago

          I think it’s fair to prevent users from causing mail sent to your internal systems. It probably won’t cause any issues getting mail to the machine inbox for (no domain name), but it reasonably makes security uneasy.

          • @xantoxis
            link
            English
            71 year ago

            The statement I was responding to was “This is the correct email regex”. There is no correct email regex. Don’t parse emails with a regex. You probably don’t need to parse emails at all.

        • @elrik
          link
          English
          41 year ago

          Yes, but no. Pretty much every application that accepts an email address on a form is going to turn around and make an API call to send that email. Guess what that API is going to do when you send it a string for a recipient address without an @ sign? It’s going to refuse it with an error.

          Therefore the correct amount of validation is that which satisfies whatever format the underlying API requires.

          For example, AWS SES requires addresses in the form UserName@[SubDomain.]Domain.TopLevelDomain along with other caveats. If the application is using SES to send emails, I’m not going to allow an input that doesn’t meet those requirements.

          • @xantoxis
            link
            English
            61 year ago

            Therefore the correct amount of validation is that which satisfies whatever format the underlying API requires.

            You mean the validation which the underlying API will perform on its own? You don’t need to do it.

            • @elrik
              link
              English
              31 year ago

              I disagree. You should have validation at each layer, as it’s easier to handle bad inputs and errors the earlier they are caught.

              It’s especially important in this case with email because often one or more of the following comes into play when you’re dealing with an email input:

              • You’re doing more than sending an email (for ex, creating a record for a new user).
              • The UI isn’t waiting for you to send that email (for ex, it’s handled through a queue or some other background process).
              • The API call to send an email has a cost (both time and money).
              • You have multiple email recipients (better hope that external API error tells you which one failed).

              I’m not suggesting that validation of an email should attempt to be exhaustive, but a well thought-out implementation validates all user inputs. Even the underlying API in this example is validating the email you give it before trying to send an email through its own underlying API.

              Passing obvious garbage inputs down is just bad practice.

      • @tomaThomas
        link
        English
        161 year ago

        Here’s my address: @@@@@

        • @[email protected]
          link
          fedilink
          English
          61 year ago

          And this right here is a great example of why simple basic RegEx is rarely adequate

          At the very least, should be something like

          ^[^@\s]+@([^@\s.]+\.)+[^@\s.]+$

          I’m like 99% sure I missed at least a few cases there, and will say “please don’t use this for anything production”

          • @jpeps
            link
            English
            41 year ago

            Here’s two: you can have multiple @s forming relays in an email address, and you can also break all the rules around dots and spaces if you put quotes around the local part, eg ".sarah.."@emails.com

            • @[email protected]
              link
              fedilink
              English
              31 year ago

              And this is exactly why I wouldn’t do my own, I had no idea either of those were legal/possible

              • @jpeps
                link
                English
                21 year ago

                To be fair nor do most email providers! It’s in the spec, though.

    • @uid0gid0
      link
      English
      41 year ago

      You should be able to double quote the local part and use the space. "like this"@email.net. Good luck getting that through a validator though.