- java.lang.Object
-
- com.aoindustries.aoserv.client.account.User.Name
-
- com.aoindustries.aoserv.client.linux.User.Name
-
- com.aoindustries.aoserv.client.mysql.User.Name
-
- All Implemented Interfaces:
DtoFactory<UserName>,FastExternalizable,Internable<User.Name>,Externalizable,Serializable,Comparable<User.Name>
- Enclosing class:
- User
public static final class User.Name extends User.Name implements FastExternalizable
Represents a MySQL user ID.Userids must:- Be non-null
- Be non-empty
- Be between 1 and 32 characters
- Must start with
[a-z] - The rest of the characters may contain
[a-z,0-9,_] - A special exemption is made for the
mysql.sessionandmysql.sysreserved users added in MySQL 5.7. - Must be a valid
User.Name- this is implied by the above rules
- Author:
- AO Industries, Inc.
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static intMYSQL_NAME_MAX_LENGTHThe maximum length of a MySQL username.-
Fields inherited from class com.aoindustries.aoserv.client.linux.User.Name
LINUX_NAME_MAX_LENGTH
-
Fields inherited from class com.aoindustries.aoserv.client.account.User.Name
MAX_LENGTH, name
-
-
Constructor Summary
Constructors Constructor Description Name()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description MySQLUserNamegetDto()longgetSerialVersionUID()User.Nameintern()Interns this name much in the same fashion asString.intern().protected voidvalidate()static ValidationResultvalidate(String name)Validates aUsername.static User.NamevalueOf(String name)-
Methods inherited from class com.aoindustries.aoserv.client.account.User.Name
compareTo, equals, hashCode, readExternal, toString, writeExternal
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.io.Externalizable
readExternal, writeExternal
-
-
-
-
Field Detail
-
MYSQL_NAME_MAX_LENGTH
public static final int MYSQL_NAME_MAX_LENGTH
The maximum length of a MySQL username.Implementation Note:
32 characters as of MySQL 5.7.8- See Also:
- Constant Field Values
-
-
Method Detail
-
validate
public static ValidationResult validate(String name)
Validates aUsername.
-
valueOf
public static User.Name valueOf(String name) throws ValidationException
- Parameters:
name- whennull, returnsnull- Throws:
ValidationException
-
validate
protected void validate() throws ValidationException- Overrides:
validatein classUser.Name- Throws:
ValidationException
-
intern
public User.Name intern()
Description copied from class:User.NameInterns this name much in the same fashion asString.intern().Because this has subtypes, two
User.Namethat areUser.Name.equals(java.lang.Object)may not necessarily return the same instance object after interning. Thus, unless you know objects are of the same class,User.Name.equals(java.lang.Object)should still be used for equality check instead of theobj1 == obj2shortcut.To more efficiently check post-interned equivalence, one could also do
obj1 == obj2 || (obj1.getClass() != obj2.getClass() && obj1.equals(obj2)), but is it worth it?And then if we abuse the fact that interned user ids have an interned name, one could check equivalence of post-interned user ids as
obj1.getId() == obj2.getId(), but once again, is it worth it? Just callUser.Name.equals(java.lang.Object).- Specified by:
internin interfaceInternable<User.Name>- Overrides:
internin classUser.Name- See Also:
String.intern()
-
getDto
public MySQLUserName getDto()
- Specified by:
getDtoin interfaceDtoFactory<UserName>- Overrides:
getDtoin classUser.Name
-
getSerialVersionUID
public long getSerialVersionUID()
- Specified by:
getSerialVersionUIDin interfaceFastExternalizable- Overrides:
getSerialVersionUIDin classUser.Name
-
-