|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectcom.google.common.net.InternetDomainName
@Beta public final class InternetDomainName
An immutable well-formed internet domain name, as defined by
RFC 1035, with the
exception that names ending in "." are not supported (as they are not
generally used in browsers, email, and other end-user applications. Examples
include com
and foo.co.uk
. Only syntactic analysis is
performed; no DNS lookups or other network interactions take place. Thus
there is no guarantee that the domain actually exists on the internet.
Invalid domain names throw IllegalArgumentException
on construction.
It is often the case that domains of interest are those under
TLDs but not themselves
TLDs; hasRecognizedTld()
and
isImmediatelyUnderTld()
test for this. Similarly, one
often needs to obtain the domain consisting of the
TLD plus one subdomain level, typically
to obtain the highest-level domain for which cookies may be set.
Use topCookieDomain()
for this purpose.
Equality of domain names is case-insensitive,
so for convenience, the name()
and parts()
methods
return the lower-case form of the name.
TLD identification is done by reference
to the generated Java class TldPatterns
, which is in turn derived
from a Mozilla-supplied text file listing known
TLD patterns.
Note that
internationalized domain names (IDN) are not supported. If IDN is
required, the ToASCII
transformation (described in the referenced
page) should be applied to the domain string before it is provided to this
class.
Method Summary | |
---|---|
InternetDomainName |
child(String leftParts)
Creates and returns a new InternetDomainName by prepending the
argument and a dot to the current name. |
boolean |
equals(Object object)
|
static InternetDomainName |
from(String domain)
A factory method for creating InternetDomainName objects. |
int |
hashCode()
|
boolean |
hasParent()
Does this domain have a parent domain? That is, does it have two or more parts? |
boolean |
hasRecognizedTld()
Returns true if the domain name ends in a
TLD, or is a complete
TLD itself. |
boolean |
isImmediatelyUnderTld()
Returns true if the domain name is an immediate subdomain of a
TLD, but is not a
TLD itself. |
boolean |
isRecognizedTld()
Returns true if the domain name is an effective top-level
domain. |
boolean |
isUnderRecognizedTld()
Returns true if the domain name ends in a
TLD, but is not a complete
TLD itself. |
static boolean |
isValid(String name)
Determines whether the argument is a syntactically valid domain name. |
String |
name()
Returns the domain name, normalized to all lower case. |
InternetDomainName |
parent()
Create a new InternetDomainName which is the parent of this one;
that is, the parent domain is the current domain with the leftmost part
removed. |
ImmutableList<String> |
parts()
Returns the parts of the domain name, normalized to all lower case. |
InternetDomainName |
recognizedTld()
Returns the TLD portion of the domain name, or null if no TLD is present according to hasRecognizedTld() . |
String |
rightmostNonTldPart()
Returns the rightmost non-TLD domain name part. |
InternetDomainName |
topCookieDomain()
Returns the "top cookie domain" for the InternetDomainName . |
String |
toString()
|
Methods inherited from class java.lang.Object |
---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
Method Detail |
---|
public static InternetDomainName from(String domain)
InternetDomainName
objects.
domain
- A domain name (not IP address)
IllegalArgumentException
- If name is not syntactically validpublic String name()
public ImmutableList<String> parts()
public boolean isRecognizedTld()
true
if the domain name is an effective top-level
domain. An effective TLD is a domain which is controlled by a national or
other registrar, and which is not itself in use as a real, separately
addressable domain name. Addressable domains occur as subdomains of
effective TLDs. Examples of TLDs include com
, co.uk
, and
ca.us
. Examples of non-TLDs include google
,
google.com
, and foo.co.uk
.
Identification of effective TLDs is done by reference to a list of patterns maintained by the Mozilla project; see the Gecko:Effective TLD List project page for details.
TODO: Note that the Mozilla TLD list does not guarantee that
the one-part TLDs like com
and us
will necessarily be
listed explicitly in the patterns file. All of the ones required for
proper operation of this class appear to be there in the current version of
the file, but this might not always be the case. We may wish to tighten
this up by providing an auxilliary source for the canonical one-part TLDs,
using the existing "amendment file" process or a similar mechanism.
public boolean isUnderRecognizedTld()
true
if the domain name ends in a
TLD, but is not a complete
TLD itself. For example, returns
true
for www.google.com
, foo.co.uk
, and
bar.ca.us
; returns false
for google
, com
,
and google.foo
.
public boolean hasRecognizedTld()
true
if the domain name ends in a
TLD, or is a complete
TLD itself. For example, returns
true
for www.google.com
, foo.co.uk
, and
com
; returns false
for google
and
google.foo
.
public InternetDomainName recognizedTld()
hasRecognizedTld()
.
public boolean isImmediatelyUnderTld()
true
if the domain name is an immediate subdomain of a
TLD, but is not a
TLD itself. For example, returns
true
for google.com
and foo.co.uk
; returns
false
for www.google.com
and co.uk
.
public String rightmostNonTldPart()
new InternetDomainName("www.google.com").rightmostNonTldPart()
returns "google"
. Returns null if either no
TLD is found, or the whole domain name is
itself a TLD.
public InternetDomainName topCookieDomain()
InternetDomainName
.
This is defined as the domain consisting of the
TLD plus one subdomain level. This
is the highest-level parent of this domain for which cookies may be set,
as cookies cannot be set on TLD
s themselves. Note that this
information has non-cookie-related uses as well, but determining the
cookie domain is the most common.
If called on a domain for which isImmediatelyUnderTld()
is
true
, this is an identity operation which returns the existing
object.
IllegalStateException
- if the domain is not under a recognized TLD.public boolean hasParent()
public InternetDomainName parent()
InternetDomainName
which is the parent of this one;
that is, the parent domain is the current domain with the leftmost part
removed. For example,
new InternetDomainName("www.google.com").parent()
returns
a new InternetDomainName
corresponding to the value
"google.com"
.
IllegalStateException
- if the domain has no parentpublic InternetDomainName child(String leftParts)
InternetDomainName
by prepending the
argument and a dot to the current name. For example,
InternetDomainName.from("foo.com").child("www.bar")
returns a
new InternetDomainName
with the value www.bar.foo.com
.
NullPointerException
- if leftParts is null
IllegalArgumentException
- if the resulting name is not validpublic static boolean isValid(String name)
String
must be
validated as a valid domain name, but no further work with that
String
as an InternetDomainName
will be required. Code
like the following will unnecessarily repeat the work of validation:
if (InternetDomainName.isValid(name)) { domainName = InternetDomainName.from(name); } else { domainName = DEFAULT_DOMAIN; }Such code should instead be written as follows:
try { domainName = InternetDomainName.from(name); } catch (IllegalArgumentException e) { domainName = DEFAULT_DOMAIN; }
public String toString()
toString
in class Object
public boolean equals(@Nullable Object object)
equals
in class Object
public int hashCode()
hashCode
in class Object
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |