mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-04 09:17:58 +01:00
47 lines
1.6 KiB
Markdown
47 lines
1.6 KiB
Markdown
# User-IDs
|
|
|
|
User-IDs are identities that users go by. A User-ID might be a name, an email address or both.
|
|
User-IDs can also contain both and even have a comment.
|
|
|
|
In general, the format of a User-ID is not fixed, so it can contain arbitrary strings.
|
|
However, it is agreed upon to use the
|
|
Below is a selection of possible User-IDs:
|
|
|
|
```
|
|
Firstname Lastname (Comment) <email@address.tld>
|
|
Firstname Lastname
|
|
Firstname Lastname (Comment)
|
|
<email@address.tld>
|
|
```
|
|
|
|
PGPainless comes with a builder class `UserId`, which can be used to safely construct User-IDs:
|
|
|
|
```java
|
|
UserId nameAndEMail = UserId.nameAndEmail("Jane Doe", "jane@pgpainless.org");
|
|
assertEquals("Jane Doe <jane@pgpainless.org>", nameAndEmail.toString()):
|
|
|
|
UserId onlyEmail = UserId.onlyEmail("john@pgpainless.org");
|
|
assertEquals("<john@pgpainless.org>", onlyEmail.toString());
|
|
|
|
UserId full = UserId.newBuilder()
|
|
.withName("Peter Pattern")
|
|
.withEmail("peter@pgpainless.org")
|
|
.withComment("Work Address")
|
|
.build();
|
|
assertEquals("Peter Pattern (Work Address) <peter@pgpainless.org>", full.toString());
|
|
```
|
|
|
|
If you have a User-ID in form of a string (e.g. because a user provided it via a text field),
|
|
you can parse it into its components like this:
|
|
|
|
```java
|
|
String string = "John Doe <john@doe.corp>";
|
|
UserId userId = UserId.parse(string);
|
|
|
|
// Now you can access the different components
|
|
assertEquals("John Doe", userId.getName());
|
|
assertEquals("john@doe.corp", userId.getEmail());
|
|
assertNull(userId.getComment());
|
|
```
|
|
|
|
The method `UserId.parse(String string)` will throw an `IllegalArgumentException` if the User-ID is malformed.
|