com.unboundid.scim.data.XmlDataFormatConfig Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scim-sdk Show documentation
Show all versions of scim-sdk Show documentation
The UnboundID SCIM SDK is a library that may be used to interact with various
types of SCIM-enabled endpoints (such as the UnboundID server products) to
perform lightweight, cloud-based identity management via the SCIM Protocol.
See http://www.simplecloud.info for more information.
/*
* Copyright 2012-2016 UnboundID Corp.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License (GPLv2 only)
* or the terms of the GNU Lesser General Public License (LGPLv2.1 only)
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see .
*/
package com.unboundid.scim.data;
import com.unboundid.scim.schema.AttributeDescriptor;
import com.unboundid.scim.sdk.InvalidResourceException;
import com.unboundid.scim.sdk.SCIMAttribute;
import com.unboundid.scim.sdk.SCIMAttributeValue;
import java.util.ArrayList;
import java.util.List;
/**
* A complex type that specifies XML data format configuration options.
*/
public class XmlDataFormatConfig
{
private final boolean supported;
/**
* The AttributeValueResolver
that resolves SCIM attribute values
* to/from XmlDataFormatConfig
instances.
*/
public static final AttributeValueResolver
XML_DATA_FORMAT_CONFIG_RESOLVER =
new AttributeValueResolver()
{
/**
* {@inheritDoc}
*/
@Override
public XmlDataFormatConfig toInstance(final SCIMAttributeValue value)
{
return new XmlDataFormatConfig(
value.getSubAttributeValue("supported",
BOOLEAN_RESOLVER));
}
/**
* {@inheritDoc}
*/
@Override
public SCIMAttributeValue fromInstance(
final AttributeDescriptor attributeDescriptor,
final XmlDataFormatConfig value)
throws InvalidResourceException
{
final List subAttributes =
new ArrayList(1);
final AttributeDescriptor supportedDescriptor =
attributeDescriptor.getSubAttribute("supported");
subAttributes.add(
SCIMAttribute.create(
supportedDescriptor,
BOOLEAN_RESOLVER.fromInstance(supportedDescriptor,
value.supported)));
return SCIMAttributeValue.createComplexValue(subAttributes);
}
};
/**
* Create a XmlDataFormatConfig
instance.
*
* @param supported Specifies whether the XML data format is supported.
*/
public XmlDataFormatConfig(final boolean supported)
{
this.supported = supported;
}
/**
* Indicates whether the XML data format is supported.
* @return {@code true} if the XML data format is supported.
*/
public boolean isSupported()
{
return supported;
}
@Override
public boolean equals(final Object o)
{
if (this == o)
{
return true;
}
if (o == null || getClass() != o.getClass())
{
return false;
}
final XmlDataFormatConfig that = (XmlDataFormatConfig) o;
if (supported != that.supported)
{
return false;
}
return true;
}
@Override
public int hashCode()
{
return (supported ? 1 : 0);
}
@Override
public String toString()
{
final StringBuilder sb = new StringBuilder();
sb.append("XmlDataFormatConfig");
sb.append("{supported=").append(supported);
sb.append('}');
return sb.toString();
}
}