package net.pterodactylus.sone.data;
/**
- * A profile stores personal information about a {@link User}. All information
+ * A profile stores personal information about a {@link Sone}. All information
* is optional and can be {@code null}.
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
public class Profile {
+ /** Whether the profile was modified. */
+ private volatile boolean modified;
+
/** The first name. */
- private String firstName;
+ private volatile String firstName;
/** The middle name(s). */
- private String middleName;
+ private volatile String middleName;
/** The last name. */
- private String lastName;
+ private volatile String lastName;
+
+ /** The day of the birth date. */
+ private volatile Integer birthDay;
+
+ /** The month of the birth date. */
+ private volatile Integer birthMonth;
+
+ /** The year of the birth date. */
+ private volatile Integer birthYear;
/**
* Creates a new empty profile.
* The profile to copy
*/
public Profile(Profile profile) {
+ if (profile == null) {
+ return;
+ }
this.firstName = profile.firstName;
this.middleName = profile.middleName;
this.lastName = profile.lastName;
+ this.birthDay = profile.birthDay;
+ this.birthMonth = profile.birthMonth;
+ this.birthYear = profile.birthYear;
}
//
//
/**
+ * Returns whether this profile was modified after creation. To clear the
+ * “is modified” flag you need to create a new profile from this one using
+ * the {@link #Profile(Profile)} constructor.
+ *
+ * @return {@code true} if this profile was modified after creation,
+ * {@code false} otherwise
+ */
+ public boolean isModified() {
+ return modified;
+ }
+
+ /**
* Returns the first name.
*
* @return The first name
*
* @param firstName
* The first name to set
+ * @return This profile (for method chaining)
*/
- public void setFirstName(String firstName) {
+ public Profile setFirstName(String firstName) {
+ modified |= ((firstName != null) && (!firstName.equals(this.firstName))) || (this.firstName != null);
this.firstName = firstName;
+ return this;
}
/**
*
* @param middleName
* The middle name to set
+ * @return This profile (for method chaining)
*/
- public void setMiddleName(String middleName) {
+ public Profile setMiddleName(String middleName) {
+ modified |= ((middleName != null) && (!middleName.equals(this.middleName))) || (this.middleName != null);
this.middleName = middleName;
+ return this;
}
/**
*
* @param lastName
* The last name to set
+ * @return This profile (for method chaining)
*/
- public void setLastName(String lastName) {
+ public Profile setLastName(String lastName) {
+ modified |= ((lastName != null) && (!lastName.equals(this.lastName))) || (this.lastName != null);
this.lastName = lastName;
+ return this;
+ }
+
+ /**
+ * Returns the day of the birth date.
+ *
+ * @return The day of the birth date (from 1 to 31)
+ */
+ public Integer getBirthDay() {
+ return birthDay;
+ }
+
+ /**
+ * Sets the day of the birth date.
+ *
+ * @param birthDay
+ * The day of the birth date (from 1 to 31)
+ * @return This profile (for method chaining)
+ */
+ public Profile setBirthDay(Integer birthDay) {
+ modified |= ((birthDay != null) && (!birthDay.equals(this.birthDay))) || (this.birthDay != null);
+ this.birthDay = birthDay;
+ return this;
+ }
+
+ /**
+ * Returns the month of the birth date.
+ *
+ * @return The month of the birth date (from 1 to 12)
+ */
+ public Integer getBirthMonth() {
+ return birthMonth;
+ }
+
+ /**
+ * Sets the month of the birth date.
+ *
+ * @param birthMonth
+ * The month of the birth date (from 1 to 12)
+ * @return This profile (for method chaining)
+ */
+ public Profile setBirthMonth(Integer birthMonth) {
+ modified |= ((birthMonth != null) && (!birthMonth.equals(this.birthMonth))) || (this.birthMonth != null);
+ this.birthMonth = birthMonth;
+ return this;
+ }
+
+ /**
+ * Returns the year of the birth date.
+ *
+ * @return The year of the birth date
+ */
+ public Integer getBirthYear() {
+ return birthYear;
+ }
+
+ /**
+ * Sets the year of the birth date.
+ *
+ * @param birthYear
+ * The year of the birth date
+ * @return This profile (for method chaining)
+ */
+ public Profile setBirthYear(Integer birthYear) {
+ modified |= ((birthYear != null) && (!birthYear.equals(this.birthYear))) || (this.birthYear != null);
+ this.birthYear = birthYear;
+ return this;
}
}