Class PathRoot
- java.lang.Object
-
- com.dropbox.core.v2.common.PathRoot
-
public final class PathRoot extends java.lang.Object
This class is an open tagged union. Tagged unions instances are always associated to a specific tag. This means only one of theisAbc()
methods will returntrue
. You can usetag()
to determine the tag associated with this instance.Open unions may be extended in the future with additional tags. If a new tag is introduced that this SDK does not recognized, the
OTHER
value will be used.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
PathRoot.Serializer
For internal use only.static class
PathRoot.Tag
Discriminating tag type forPathRoot
.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
equals(java.lang.Object obj)
java.lang.String
getNamespaceIdValue()
Paths are relative to given namespace id (This results inPathRootError.NO_PERMISSION
if you don't have access to this namespace.).java.lang.String
getRootValue()
Paths are relative to the authenticating user's root namespace (This results inPathRootError.getInvalidRootValue()
if the user's root namespace has changed.).int
hashCode()
boolean
isHome()
boolean
isNamespaceId()
boolean
isOther()
boolean
isRoot()
static PathRoot
namespaceId(java.lang.String value)
Returns an instance ofPathRoot
that has its tag set toPathRoot.Tag.NAMESPACE_ID
.static PathRoot
root(java.lang.String value)
Returns an instance ofPathRoot
that has its tag set toPathRoot.Tag.ROOT
.PathRoot.Tag
tag()
Returns the tag for this instance.java.lang.String
toString()
java.lang.String
toStringMultiline()
Returns a String representation of this object formatted for easier readability.
-
-
-
Field Detail
-
HOME
public static final PathRoot HOME
Paths are relative to the authenticating user's home namespace, whether or not that user belongs to a team.
-
OTHER
public static final PathRoot OTHER
Catch-all used for unknown tag values returned by the Dropbox servers.Receiving a catch-all value typically indicates this SDK version is not up to date. Consider updating your SDK version to handle the new tags.
-
-
Method Detail
-
tag
public PathRoot.Tag tag()
Returns the tag for this instance.This class is a tagged union. Tagged unions instances are always associated to a specific tag. This means only one of the
isXyz()
methods will returntrue
. Callers are recommended to use the tag value in aswitch
statement to properly handle the different values for thisPathRoot
.If a tag returned by the server is unrecognized by this SDK, the
PathRoot.Tag.OTHER
value will be used.- Returns:
- the tag for this instance.
-
isHome
public boolean isHome()
- Returns:
true
if this instance is tagged asPathRoot.Tag.HOME
,false
otherwise.
-
isRoot
public boolean isRoot()
- Returns:
true
if this instance is tagged asPathRoot.Tag.ROOT
,false
otherwise.
-
root
public static PathRoot root(java.lang.String value)
Returns an instance ofPathRoot
that has its tag set toPathRoot.Tag.ROOT
.Paths are relative to the authenticating user's root namespace (This results in
PathRootError.getInvalidRootValue()
if the user's root namespace has changed.).- Parameters:
value
- value to assign to this instance.- Returns:
- Instance of
PathRoot
with its tag set toPathRoot.Tag.ROOT
. - Throws:
java.lang.IllegalArgumentException
- ifvalue
does not match pattern "[-_0-9a-zA-Z:]+
" or isnull
.
-
getRootValue
public java.lang.String getRootValue()
Paths are relative to the authenticating user's root namespace (This results inPathRootError.getInvalidRootValue()
if the user's root namespace has changed.).This instance must be tagged as
PathRoot.Tag.ROOT
.
-
isNamespaceId
public boolean isNamespaceId()
- Returns:
true
if this instance is tagged asPathRoot.Tag.NAMESPACE_ID
,false
otherwise.
-
namespaceId
public static PathRoot namespaceId(java.lang.String value)
Returns an instance ofPathRoot
that has its tag set toPathRoot.Tag.NAMESPACE_ID
.Paths are relative to given namespace id (This results in
PathRootError.NO_PERMISSION
if you don't have access to this namespace.).- Parameters:
value
- value to assign to this instance.- Returns:
- Instance of
PathRoot
with its tag set toPathRoot.Tag.NAMESPACE_ID
. - Throws:
java.lang.IllegalArgumentException
- ifvalue
does not match pattern "[-_0-9a-zA-Z:]+
" or isnull
.
-
getNamespaceIdValue
public java.lang.String getNamespaceIdValue()
Paths are relative to given namespace id (This results inPathRootError.NO_PERMISSION
if you don't have access to this namespace.).This instance must be tagged as
PathRoot.Tag.NAMESPACE_ID
.- Returns:
- The
String
value associated with this instance ifisNamespaceId()
istrue
. - Throws:
java.lang.IllegalStateException
- IfisNamespaceId()
isfalse
.
-
isOther
public boolean isOther()
- Returns:
true
if this instance is tagged asPathRoot.Tag.OTHER
,false
otherwise.
-
hashCode
public int hashCode()
- Overrides:
hashCode
in classjava.lang.Object
-
equals
public boolean equals(java.lang.Object obj)
- Overrides:
equals
in classjava.lang.Object
-
toString
public java.lang.String toString()
- Overrides:
toString
in classjava.lang.Object
-
toStringMultiline
public java.lang.String toStringMultiline()
Returns a String representation of this object formatted for easier readability.The returned String may contain newlines.
- Returns:
- Formatted, multiline String representation of this object
-
-