Reworking the Actions parameter object per the updated Action Handlers
spec (http://tools.ietf.org/html/draft-snell-activitystreams-actions-05)
This commit is contained in:
parent
f01e302aa2
commit
478d497d1a
|
@ -134,5 +134,9 @@
|
||||||
<artifactId>activitystreams-core</artifactId>
|
<artifactId>activitystreams-core</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
|
@ -43,6 +43,10 @@ public abstract class ActionHandler
|
||||||
private final Authentication.Builder auth =
|
private final Authentication.Builder auth =
|
||||||
Authentication.make();
|
Authentication.make();
|
||||||
|
|
||||||
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method confirm.
|
* Method confirm.
|
||||||
* @return B
|
* @return B
|
||||||
|
@ -361,4 +365,5 @@ public abstract class ActionHandler
|
||||||
return auth != null ?
|
return auth != null ?
|
||||||
(A)auth.get(key) : null;
|
(A)auth.get(key) : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,11 +24,18 @@ package com.ibm.common.activitystreams.actions;
|
||||||
import static com.ibm.common.activitystreams.Makers.object;
|
import static com.ibm.common.activitystreams.Makers.object;
|
||||||
|
|
||||||
import com.ibm.common.activitystreams.ASObject;
|
import com.ibm.common.activitystreams.ASObject;
|
||||||
|
import com.ibm.common.activitystreams.IO;
|
||||||
|
import com.ibm.common.activitystreams.actions.ParameterValue.SimpleParameterValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
public final class ActionMakers {
|
public final class ActionMakers {
|
||||||
|
|
||||||
|
public static final IO io =
|
||||||
|
IO.makeDefault(ActionsModule.instance);
|
||||||
|
public static final IO ioPretty =
|
||||||
|
IO.makeDefaultPrettyPrint(ActionsModule.instance);
|
||||||
|
|
||||||
public static final String TARGET_NONE = "NONE";
|
public static final String TARGET_NONE = "NONE";
|
||||||
public static final String TARGET_DEFAULT = "DEFAULT";
|
public static final String TARGET_DEFAULT = "DEFAULT";
|
||||||
public static final String TARGET_NEW = "NEW";
|
public static final String TARGET_NEW = "NEW";
|
||||||
|
@ -220,7 +227,7 @@ public final class ActionMakers {
|
||||||
* @param id String
|
* @param id String
|
||||||
* @return Parameter.Builder
|
* @return Parameter.Builder
|
||||||
*/
|
*/
|
||||||
public static Parameter.Builder parameter(String id) {
|
public static SimpleParameterValue parameter(String id) {
|
||||||
return parameter().id(id);
|
return new SimpleParameterValue.Builder().type(id).get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
package com.ibm.common.activitystreams.actions;
|
package com.ibm.common.activitystreams.actions;
|
||||||
|
|
||||||
import static com.ibm.common.activitystreams.actions.Adapters.AUTH;
|
import static com.ibm.common.activitystreams.actions.Adapters.AUTH;
|
||||||
import static com.ibm.common.activitystreams.actions.Adapters.PARAMETERS;
|
|
||||||
import static com.ibm.common.activitystreams.actions.Adapters.STYLES;
|
import static com.ibm.common.activitystreams.actions.Adapters.STYLES;
|
||||||
|
|
||||||
import com.ibm.common.activitystreams.IO.Builder;
|
import com.ibm.common.activitystreams.IO.Builder;
|
||||||
|
@ -47,10 +46,10 @@ public final class ActionsModule
|
||||||
.hierarchicalAdapter(IntentActionHandler.class,base)
|
.hierarchicalAdapter(IntentActionHandler.class,base)
|
||||||
.hierarchicalAdapter(EmbedActionHandler.class,base)
|
.hierarchicalAdapter(EmbedActionHandler.class,base)
|
||||||
.hierarchicalAdapter(HtmlForm.class,base)
|
.hierarchicalAdapter(HtmlForm.class,base)
|
||||||
|
.hierarchicalAdapter(ParametersValue.class, ParametersAdapter.instance)
|
||||||
|
.hierarchicalAdapter(ParameterValue.class, ParameterAdapter.instance)
|
||||||
.hierarchicalAdapter(UrlTemplate.class,base)
|
.hierarchicalAdapter(UrlTemplate.class,base)
|
||||||
.hierarchicalAdapter(TypedPayload.class,base)
|
.hierarchicalAdapter(TypedPayload.class,base)
|
||||||
.hierarchicalAdapter(Parameter.class,base)
|
|
||||||
.hierarchicalAdapter(ParametersValue.class, PARAMETERS)
|
|
||||||
.hierarchicalAdapter(Authentication.class, AUTH)
|
.hierarchicalAdapter(Authentication.class, AUTH)
|
||||||
.hierarchicalAdapter(StylesValue.class, STYLES);
|
.hierarchicalAdapter(StylesValue.class, STYLES);
|
||||||
}
|
}
|
||||||
|
@ -58,7 +57,6 @@ public final class ActionsModule
|
||||||
@Override
|
@Override
|
||||||
public void apply(Schema.Builder builder) {
|
public void apply(Schema.Builder builder) {
|
||||||
builder.map("HtmlForm", withParameters.template(HtmlForm.class, HtmlForm.Builder.class))
|
builder.map("HtmlForm", withParameters.template(HtmlForm.class, HtmlForm.Builder.class))
|
||||||
.map("parameter", parameter)
|
|
||||||
.map("TypedPayload", typedPayload)
|
.map("TypedPayload", typedPayload)
|
||||||
.map("UrlTemplate", withParameters.template(UrlTemplate.class, UrlTemplate.Builder.class))
|
.map("UrlTemplate", withParameters.template(UrlTemplate.class, UrlTemplate.Builder.class))
|
||||||
.map("HttpActionHandler", actionHandler.template(HttpActionHandler.class, HttpActionHandler.Builder.class))
|
.map("HttpActionHandler", actionHandler.template(HttpActionHandler.class, HttpActionHandler.Builder.class))
|
||||||
|
@ -89,15 +87,11 @@ public final class ActionsModule
|
||||||
public final static Model typedPayload =
|
public final static Model typedPayload =
|
||||||
Model
|
Model
|
||||||
.make("object")
|
.make("object")
|
||||||
|
.type(TypedPayload.class, TypedPayload.Builder.class)
|
||||||
.linkValue("schema")
|
.linkValue("schema")
|
||||||
.typeValue("type")
|
.typeValue("type")
|
||||||
.get();
|
.get();
|
||||||
|
|
||||||
public final static Model parameter =
|
|
||||||
Model
|
|
||||||
.make("object")
|
|
||||||
.typeValue("type")
|
|
||||||
.type(Parameter.class, Parameter.Builder.class)
|
|
||||||
.get();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,17 +42,6 @@ final class Adapters {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static final Adapter<ParametersValue> PARAMETERS =
|
|
||||||
new AbstractDictionaryObjectAdapter
|
|
||||||
<TypeValue,
|
|
||||||
ParametersValue,
|
|
||||||
ParametersValue.Builder>(TypeValue.class) {
|
|
||||||
@Override
|
|
||||||
protected ParametersValue.Builder builder() {
|
|
||||||
return ParametersValue.make();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
static final Adapter<StylesValue> STYLES =
|
static final Adapter<StylesValue> STYLES =
|
||||||
new AbstractDictionaryObjectAdapter
|
new AbstractDictionaryObjectAdapter
|
||||||
<String,
|
<String,
|
||||||
|
|
|
@ -47,6 +47,10 @@ public final class Authentication
|
||||||
extends AbstractDictionaryObject.AbstractBuilder<
|
extends AbstractDictionaryObject.AbstractBuilder<
|
||||||
ASObject,Authentication,Builder> {
|
ASObject,Authentication,Builder> {
|
||||||
|
|
||||||
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method get.
|
* Method get.
|
||||||
* @return Authentication
|
* @return Authentication
|
||||||
|
|
|
@ -29,6 +29,7 @@ import java.io.ObjectStreamException;
|
||||||
import com.google.common.base.Supplier;
|
import com.google.common.base.Supplier;
|
||||||
import com.ibm.common.activitystreams.ASObject;
|
import com.ibm.common.activitystreams.ASObject;
|
||||||
import com.ibm.common.activitystreams.TypeValue;
|
import com.ibm.common.activitystreams.TypeValue;
|
||||||
|
import com.ibm.common.activitystreams.actions.UrlTemplate.Builder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
|
@ -51,86 +52,28 @@ public final class HtmlForm
|
||||||
private final ParametersValue.Builder params =
|
private final ParametersValue.Builder params =
|
||||||
ParametersValue.make();
|
ParametersValue.make();
|
||||||
|
|
||||||
private Builder() {
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
objectType("HtmlForm");
|
objectType("HtmlForm");
|
||||||
mediaType("application/x-www-form-urlencoded");
|
mediaType("application/x-www-form-urlencoded");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public Builder parameter(String name, String iri) {
|
||||||
* Method parameter.
|
params.param(name, iri);
|
||||||
* @param name String
|
|
||||||
* @param iri String
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
|
||||||
String name,
|
|
||||||
String iri) {
|
|
||||||
params.set(name, type(iri));
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param iri String
|
|
||||||
* @param required boolean
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
public Builder parameter(
|
||||||
String name,
|
String name,
|
||||||
String iri,
|
ParameterValue parameter) {
|
||||||
boolean required) {
|
params.param(name, parameter);
|
||||||
return parameter(
|
|
||||||
name,
|
|
||||||
object()
|
|
||||||
.id(iri)
|
|
||||||
.set("required", required));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param iri String
|
|
||||||
* @param required boolean
|
|
||||||
* @param value Object
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
|
||||||
String name,
|
|
||||||
String iri,
|
|
||||||
boolean required,
|
|
||||||
Object value) {
|
|
||||||
return parameter(
|
|
||||||
name,
|
|
||||||
object()
|
|
||||||
.id(iri)
|
|
||||||
.set("required", required)
|
|
||||||
.set("value", value));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param lv TypeValue
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
|
||||||
String name,
|
|
||||||
TypeValue lv) {
|
|
||||||
params.set(name, lv);
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param lv Supplier<? extends TypeValue>
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
public Builder parameter(
|
||||||
String name,
|
String name,
|
||||||
Supplier<? extends TypeValue> lv) {
|
Supplier<? extends ParameterValue> parameter) {
|
||||||
return parameter(name, lv.get());
|
return parameter(name, parameter.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,260 @@
|
||||||
|
package com.ibm.common.activitystreams.actions;
|
||||||
|
|
||||||
|
import java.lang.reflect.Type;
|
||||||
|
|
||||||
|
import static com.google.common.base.Preconditions.checkArgument;
|
||||||
|
|
||||||
|
import com.google.common.collect.Iterables;
|
||||||
|
import com.google.gson.JsonDeserializationContext;
|
||||||
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import com.google.gson.JsonParseException;
|
||||||
|
import com.google.gson.JsonPrimitive;
|
||||||
|
import com.google.gson.JsonSerializationContext;
|
||||||
|
import com.ibm.common.activitystreams.ASObject;
|
||||||
|
import com.ibm.common.activitystreams.NLV;
|
||||||
|
import com.ibm.common.activitystreams.actions.ParameterValue.SimpleParameterValue;
|
||||||
|
import com.ibm.common.activitystreams.internal.Adapter;
|
||||||
|
|
||||||
|
public final class ParameterAdapter
|
||||||
|
extends Adapter<ParameterValue> {
|
||||||
|
|
||||||
|
public static final ParameterAdapter instance =
|
||||||
|
new ParameterAdapter();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public JsonElement serialize(
|
||||||
|
ParameterValue src,
|
||||||
|
Type typeOfSrc,
|
||||||
|
JsonSerializationContext context) {
|
||||||
|
|
||||||
|
if (src == null) return null;
|
||||||
|
switch(src.valueType()) {
|
||||||
|
case OBJECT:
|
||||||
|
if (src instanceof Parameter) {
|
||||||
|
Parameter parameter = (Parameter) src;
|
||||||
|
JsonObject obj = new JsonObject();
|
||||||
|
if (parameter.has("type")) {
|
||||||
|
String type = parameter.type();
|
||||||
|
if (type != null)
|
||||||
|
obj.addProperty("type", type);
|
||||||
|
}
|
||||||
|
if (parameter.has("displayName")) {
|
||||||
|
NLV nlv = parameter.displayName();
|
||||||
|
if (nlv != null)
|
||||||
|
obj.add("displayName", context.serialize(nlv, NLV.class));
|
||||||
|
}
|
||||||
|
if (parameter.has("placeholder")) {
|
||||||
|
NLV nlv = parameter.placeholder();
|
||||||
|
if (nlv != null)
|
||||||
|
obj.add("placeholder", context.serialize(nlv, NLV.class));
|
||||||
|
}
|
||||||
|
if (parameter.has("enumeration")) {
|
||||||
|
Iterable<Object> e = parameter.enumeration();
|
||||||
|
if (e != null)
|
||||||
|
obj.add("enumeration", context.serialize(e,e.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("language")) {
|
||||||
|
String lang = parameter.language();
|
||||||
|
if (lang != null)
|
||||||
|
obj.addProperty("language", lang);
|
||||||
|
}
|
||||||
|
if (parameter.has("maxInclusive")) {
|
||||||
|
Object max = parameter.maxInclusive();
|
||||||
|
if (max != null)
|
||||||
|
obj.add("maxInclusive", context.serialize(max, max.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("maxExclusive")) {
|
||||||
|
Object max = parameter.maxExclusive();
|
||||||
|
if (max != null)
|
||||||
|
obj.add("maxExclusive", context.serialize(max, max.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("minInclusive")) {
|
||||||
|
Object max = parameter.minInclusive();
|
||||||
|
if (max != null)
|
||||||
|
obj.add("minInclusive", context.serialize(max, max.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("minExclusive")) {
|
||||||
|
Object max = parameter.minExclusive();
|
||||||
|
if (max != null)
|
||||||
|
obj.add("minExclusive", context.serialize(max, max.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("pattern")) {
|
||||||
|
Iterable<String> pattern = parameter.pattern();
|
||||||
|
if (pattern != null) {
|
||||||
|
if (Iterables.size(pattern) == 0) {
|
||||||
|
String first = Iterables.getFirst(pattern, null);
|
||||||
|
if (first != null)
|
||||||
|
obj.addProperty("pattern", first);
|
||||||
|
} else
|
||||||
|
obj.add("pattern", context.serialize(pattern, pattern.getClass()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (parameter.has("repeated")) {
|
||||||
|
boolean repeated = parameter.repeated();
|
||||||
|
if (repeated)
|
||||||
|
obj.addProperty("repeated", repeated);
|
||||||
|
}
|
||||||
|
if (parameter.has("required")) {
|
||||||
|
boolean required = parameter.required();
|
||||||
|
if (!required)
|
||||||
|
obj.addProperty("required", required);
|
||||||
|
}
|
||||||
|
if (parameter.has("step")) {
|
||||||
|
Number n = parameter.step();
|
||||||
|
if (n != null)
|
||||||
|
obj.add("step", context.serialize(n,n.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("default")) {
|
||||||
|
Object def = parameter.defaultValue();
|
||||||
|
if (def != null)
|
||||||
|
obj.add("default",context.serialize(def, def.getClass()));
|
||||||
|
}
|
||||||
|
if (parameter.has("minLength")) {
|
||||||
|
int len = parameter.minLength();
|
||||||
|
if (len > -1)
|
||||||
|
obj.addProperty("minLength", len);
|
||||||
|
}
|
||||||
|
if (parameter.has("maxLength")) {
|
||||||
|
int len = parameter.maxLength();
|
||||||
|
if (len > -1)
|
||||||
|
obj.addProperty("maxLength", len);
|
||||||
|
}
|
||||||
|
if (parameter.has("totalDigits")) {
|
||||||
|
int len = parameter.totalDigits();
|
||||||
|
if (len > -1)
|
||||||
|
obj.addProperty("totalDigits", len);
|
||||||
|
}
|
||||||
|
if (parameter.has("fractionDigits")) {
|
||||||
|
int len = parameter.fractionDigits();
|
||||||
|
if (len > -1)
|
||||||
|
obj.addProperty("fractionDigits", len);
|
||||||
|
}
|
||||||
|
if (parameter.has("value")) {
|
||||||
|
Object val = parameter.value();
|
||||||
|
if (val != null)
|
||||||
|
obj.add("value", context.serialize(val, val.getClass()));
|
||||||
|
}
|
||||||
|
return obj;
|
||||||
|
} else if (src instanceof UrlTemplate) {
|
||||||
|
return context.serialize(src, UrlTemplate.class);
|
||||||
|
} else if (src instanceof TypedPayload) {
|
||||||
|
return context.serialize(src, TypedPayload.class);
|
||||||
|
} else if (src instanceof ASObject) {
|
||||||
|
return context.serialize(src, ASObject.class);
|
||||||
|
} else throw new IllegalArgumentException();
|
||||||
|
case SIMPLE:
|
||||||
|
SimpleParameterValue spv = (SimpleParameterValue) src;
|
||||||
|
return context.serialize(spv.type(), String.class);
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Object deserialize(
|
||||||
|
JsonDeserializationContext context,
|
||||||
|
JsonElement el) {
|
||||||
|
if (el.isJsonArray()) {
|
||||||
|
return context.deserialize(el, Iterable.class);
|
||||||
|
} else if (el.isJsonObject()) {
|
||||||
|
return context.deserialize(el, ASObject.class);
|
||||||
|
} else if (el.isJsonPrimitive()) {
|
||||||
|
JsonPrimitive p = el.getAsJsonPrimitive();
|
||||||
|
if (p.isBoolean())
|
||||||
|
return p.getAsBoolean();
|
||||||
|
else if (p.isNumber())
|
||||||
|
return p.getAsNumber();
|
||||||
|
else
|
||||||
|
return p.getAsString();
|
||||||
|
} else return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ParameterValue deserialize(
|
||||||
|
JsonElement json,
|
||||||
|
Type typeOfT,
|
||||||
|
JsonDeserializationContext context)
|
||||||
|
throws JsonParseException {
|
||||||
|
|
||||||
|
checkArgument(json.isJsonPrimitive() || json.isJsonObject());
|
||||||
|
|
||||||
|
if (json.isJsonPrimitive()) {
|
||||||
|
JsonPrimitive jp = json.getAsJsonPrimitive();
|
||||||
|
checkArgument(jp.isString());
|
||||||
|
return ActionMakers.parameter(jp.getAsString());
|
||||||
|
} else {
|
||||||
|
JsonObject obj = json.getAsJsonObject();
|
||||||
|
if (obj.has("objectType")) {
|
||||||
|
ASObject as = context.deserialize(obj, ASObject.class);
|
||||||
|
checkArgument(as instanceof ParameterValue);
|
||||||
|
return (ParameterValue) as;
|
||||||
|
} else {
|
||||||
|
Parameter.Builder builder =
|
||||||
|
ActionMakers.parameter();
|
||||||
|
if (obj.has("default"))
|
||||||
|
builder.defaultValue(
|
||||||
|
deserialize(context, obj.get("default")));
|
||||||
|
if (obj.has("displayName"))
|
||||||
|
builder.displayName(
|
||||||
|
context.<NLV>deserialize(
|
||||||
|
obj.get("displayName"),
|
||||||
|
NLV.class));
|
||||||
|
if (obj.has("enumeration"))
|
||||||
|
builder.enumeration(
|
||||||
|
context.<Iterable<?>>deserialize(
|
||||||
|
obj.get("enumeration"),
|
||||||
|
Iterable.class));
|
||||||
|
if (obj.has("fractionDigits"))
|
||||||
|
builder.fractionDigits(
|
||||||
|
obj.get("fractionDigits").getAsInt());
|
||||||
|
if (obj.has("language"))
|
||||||
|
builder.language(
|
||||||
|
obj.get("language").getAsString());
|
||||||
|
if (obj.has("maxExclusive"))
|
||||||
|
builder.maxExclusive(
|
||||||
|
deserialize(context, obj.get("maxExclusive")));
|
||||||
|
if (obj.has("maxInclusive"))
|
||||||
|
builder.maxInclusive(
|
||||||
|
deserialize(context, obj.get("maxInclusive")));
|
||||||
|
if (obj.has("minExclusive"))
|
||||||
|
builder.minExclusive(
|
||||||
|
deserialize(context, obj.get("minExclusive")));
|
||||||
|
if (obj.has("minInclusive"))
|
||||||
|
builder.minInclusive(
|
||||||
|
deserialize(context, obj.get("minInclusive")));
|
||||||
|
if (obj.has("maxLength"))
|
||||||
|
builder.maxLength(
|
||||||
|
obj.get("maxLength").getAsInt());
|
||||||
|
if (obj.has("minLength"))
|
||||||
|
builder.minLength(
|
||||||
|
obj.get("minLength").getAsInt());
|
||||||
|
if (obj.has("pattern"))
|
||||||
|
builder.pattern(
|
||||||
|
context.<Iterable<String>>deserialize(
|
||||||
|
obj.get("pattern"), Iterable.class));
|
||||||
|
if (obj.has("placeholder"))
|
||||||
|
builder.placeholder(
|
||||||
|
context.<NLV>deserialize(
|
||||||
|
obj.get("placeholder"), NLV.class));
|
||||||
|
if (obj.has("repeated") && obj.get("repeated").getAsBoolean())
|
||||||
|
builder.repeated();
|
||||||
|
if (obj.has("required") && !obj.get("required").getAsBoolean())
|
||||||
|
builder.optional();
|
||||||
|
if (obj.has("step"))
|
||||||
|
builder.step(
|
||||||
|
obj.get("step").getAsNumber());
|
||||||
|
if (obj.has("totalDigits"))
|
||||||
|
builder.totalDigits(
|
||||||
|
obj.get("totalDigits").getAsInt());
|
||||||
|
if (obj.has("type"))
|
||||||
|
builder.type(
|
||||||
|
obj.get("type").getAsString());
|
||||||
|
if (obj.has("value"))
|
||||||
|
builder.value(
|
||||||
|
deserialize(context, obj.get("value")));
|
||||||
|
return builder.get();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,99 @@
|
||||||
|
package com.ibm.common.activitystreams.actions;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
import com.ibm.common.activitystreams.IO;
|
||||||
|
import com.ibm.common.activitystreams.ValueType;
|
||||||
|
import com.ibm.common.activitystreams.Writable;
|
||||||
|
import com.ibm.common.activitystreams.util.AbstractWritable;
|
||||||
|
import com.sun.org.apache.xalan.internal.utils.Objects;
|
||||||
|
|
||||||
|
public interface ParameterValue
|
||||||
|
extends Writable, Serializable {
|
||||||
|
|
||||||
|
ValueType valueType();
|
||||||
|
|
||||||
|
String toString(IO io);
|
||||||
|
|
||||||
|
public static final class SimpleParameterValue
|
||||||
|
extends AbstractWritable
|
||||||
|
implements ParameterValue {
|
||||||
|
|
||||||
|
static final class Builder
|
||||||
|
extends AbstractWritable.AbstractWritableBuilder<SimpleParameterValue,Builder> {
|
||||||
|
|
||||||
|
private String type;
|
||||||
|
|
||||||
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder type(String type) {
|
||||||
|
this.type = type;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SimpleParameterValue get() {
|
||||||
|
return new SimpleParameterValue(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private final String type;
|
||||||
|
|
||||||
|
private SimpleParameterValue(Builder b) {
|
||||||
|
super(b);
|
||||||
|
this.type = b.type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ValueType valueType() {
|
||||||
|
return ValueType.SIMPLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String type() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hashCode(type);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
SimpleParameterValue other = (SimpleParameterValue) obj;
|
||||||
|
return Objects.equals(type,other.type);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString(IO io) {
|
||||||
|
return super.toString(io);
|
||||||
|
}
|
||||||
|
|
||||||
|
Object writeReplace() throws java.io.ObjectStreamException {
|
||||||
|
return new SerializedForm(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class SerializedForm
|
||||||
|
implements Serializable {
|
||||||
|
private static final long serialVersionUID = -1975376657749952999L;
|
||||||
|
private String type;
|
||||||
|
SerializedForm(SimpleParameterValue obj) {
|
||||||
|
this.type = obj.type;
|
||||||
|
}
|
||||||
|
|
||||||
|
Object readResolve()
|
||||||
|
throws java.io.ObjectStreamException {
|
||||||
|
return new SimpleParameterValue.Builder().type(type).get();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,57 @@
|
||||||
|
package com.ibm.common.activitystreams.actions;
|
||||||
|
|
||||||
|
import java.lang.reflect.Type;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static com.google.common.base.Preconditions.checkArgument;
|
||||||
|
|
||||||
|
import com.google.gson.JsonDeserializationContext;
|
||||||
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import com.google.gson.JsonParseException;
|
||||||
|
import com.google.gson.JsonSerializationContext;
|
||||||
|
import com.ibm.common.activitystreams.internal.Adapter;
|
||||||
|
|
||||||
|
public final class ParametersAdapter
|
||||||
|
extends Adapter<ParametersValue> {
|
||||||
|
|
||||||
|
public static final ParametersAdapter instance =
|
||||||
|
new ParametersAdapter();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public JsonElement serialize(
|
||||||
|
ParametersValue params,
|
||||||
|
Type type,
|
||||||
|
JsonSerializationContext context) {
|
||||||
|
if (params == null) return null;
|
||||||
|
JsonObject obj = new JsonObject();
|
||||||
|
for (String param : params) {
|
||||||
|
obj.add(
|
||||||
|
param,
|
||||||
|
context.serialize(
|
||||||
|
params.get(param),
|
||||||
|
ParameterValue.class));
|
||||||
|
}
|
||||||
|
return obj;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ParametersValue deserialize(
|
||||||
|
JsonElement json,
|
||||||
|
Type type,
|
||||||
|
JsonDeserializationContext context)
|
||||||
|
throws JsonParseException {
|
||||||
|
checkArgument(json.isJsonObject());
|
||||||
|
JsonObject obj = json.getAsJsonObject();
|
||||||
|
ParametersValue.Builder builder =
|
||||||
|
ParametersValue.make();
|
||||||
|
for (Map.Entry<String,JsonElement> entry : obj.entrySet())
|
||||||
|
builder.param(
|
||||||
|
entry.getKey(),
|
||||||
|
context.<ParameterValue>deserialize(
|
||||||
|
entry.getValue(),
|
||||||
|
ParameterValue.class));
|
||||||
|
return builder.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -22,13 +22,13 @@
|
||||||
package com.ibm.common.activitystreams.actions;
|
package com.ibm.common.activitystreams.actions;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import com.google.common.base.Supplier;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import com.ibm.common.activitystreams.ASObject;
|
import com.google.common.collect.Maps;
|
||||||
import com.ibm.common.activitystreams.TypeValue;
|
import com.ibm.common.activitystreams.util.AbstractWritable;
|
||||||
import com.ibm.common.activitystreams.ValueType;
|
|
||||||
import com.ibm.common.activitystreams.util.AbstractDictionaryObject;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The value of the "parameters" property...
|
* The value of the "parameters" property...
|
||||||
|
@ -36,113 +36,79 @@ import com.ibm.common.activitystreams.util.AbstractDictionaryObject;
|
||||||
* @version $Revision: 1.0 $
|
* @version $Revision: 1.0 $
|
||||||
*/
|
*/
|
||||||
public final class ParametersValue
|
public final class ParametersValue
|
||||||
extends AbstractDictionaryObject<TypeValue>
|
extends AbstractWritable
|
||||||
implements Serializable {
|
implements Serializable, Iterable<String> {
|
||||||
|
|
||||||
/**
|
|
||||||
* Method make.
|
|
||||||
|
|
||||||
* @return Builder */
|
|
||||||
public static Builder make() {
|
public static Builder make() {
|
||||||
return new Builder();
|
return new Builder();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author james
|
* @author james
|
||||||
* @version $Revision: 1.0 $
|
* @version $Revision: 1.0 $
|
||||||
*/
|
*/
|
||||||
public static final class Builder
|
public static final class Builder
|
||||||
extends AbstractDictionaryObject.AbstractBuilder
|
extends AbstractWritable.AbstractWritableBuilder
|
||||||
<TypeValue,ParametersValue,Builder> {
|
<ParametersValue,Builder> {
|
||||||
|
|
||||||
/**
|
private final Map<String,Object> params =
|
||||||
* Method set.
|
Maps.newHashMap();
|
||||||
* @param param String
|
|
||||||
* @param iri String
|
|
||||||
|
|
||||||
* @return Builder */
|
public Builder() {
|
||||||
public Builder set(String param, String iri) {
|
writeUsing(ActionMakers.io);
|
||||||
return super.set(
|
|
||||||
param,
|
|
||||||
TypeValue.SimpleTypeValue.make(iri));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public boolean notEmpty() {
|
||||||
* Method get.
|
return !params.isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder param(String param, String iri) {
|
||||||
|
params.put(param, ActionMakers.parameter(iri));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder param(
|
||||||
|
String param,
|
||||||
|
ParameterValue parameter) {
|
||||||
|
params.put(param, parameter);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder param(
|
||||||
|
String param,
|
||||||
|
Supplier<? extends ParameterValue> parameter) {
|
||||||
|
params.put(param, parameter);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
* @return ParametersValue * @see com.google.common.base.Supplier#get() */
|
|
||||||
public ParametersValue get() {
|
public ParametersValue get() {
|
||||||
return new ParametersValue(this);
|
return new ParametersValue(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private final ImmutableMap<String,Object> params;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor for ParametersValue.
|
* Constructor for ParametersValue.
|
||||||
* @param builder Builder
|
* @param builder Builder
|
||||||
*/
|
*/
|
||||||
ParametersValue(Builder builder) {
|
ParametersValue(Builder builder) {
|
||||||
super(builder);
|
super(builder);
|
||||||
|
this.params = ImmutableMap.copyOf(builder.params);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public Iterator<String> iterator() {
|
||||||
* Method get.
|
return params.keySet().iterator();
|
||||||
* @param param String
|
}
|
||||||
|
|
||||||
* @return TypeValue */
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public <T extends TypeValue>T get(String param) {
|
public <O extends ParameterValue>O get(String param) {
|
||||||
return (T)super.getSingle(param);
|
return (O)params.get(param);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public boolean has(String param) {
|
||||||
* Method id.
|
return params.containsKey(param);
|
||||||
* @param param String
|
|
||||||
* @return String
|
|
||||||
*/
|
|
||||||
public String id(String param) {
|
|
||||||
TypeValue tv = get(param);
|
|
||||||
return tv != null ? tv.id() : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method required.
|
|
||||||
* @param param String
|
|
||||||
* @return boolean
|
|
||||||
*/
|
|
||||||
public boolean required(String param) {
|
|
||||||
TypeValue tv = get(param);
|
|
||||||
if (tv == null)
|
|
||||||
return false;
|
|
||||||
if (tv.valueType() == ValueType.SIMPLE)
|
|
||||||
return true;
|
|
||||||
ASObject obj = (ASObject) tv;
|
|
||||||
return obj.getBoolean("required", true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method value.
|
|
||||||
* @param param String
|
|
||||||
* @param defaultValue O
|
|
||||||
* @return O
|
|
||||||
*/
|
|
||||||
public <O>O value(String param, O defaultValue) {
|
|
||||||
TypeValue tv = get(param);
|
|
||||||
if (tv == null || tv.valueType() == ValueType.SIMPLE)
|
|
||||||
return defaultValue;
|
|
||||||
ASObject obj = (ASObject) tv;
|
|
||||||
return obj.<O>get("value", defaultValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method value.
|
|
||||||
* @param param String
|
|
||||||
* @return O
|
|
||||||
*/
|
|
||||||
public <O>O value(String param) {
|
|
||||||
return value(param,null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Object writeReplace() throws java.io.ObjectStreamException {
|
Object writeReplace() throws java.io.ObjectStreamException {
|
||||||
|
@ -154,19 +120,14 @@ public final class ParametersValue
|
||||||
private static final long serialVersionUID = -1975376657749952999L;
|
private static final long serialVersionUID = -1975376657749952999L;
|
||||||
private ImmutableMap<String,Object> map;
|
private ImmutableMap<String,Object> map;
|
||||||
SerializedForm(ParametersValue obj) {
|
SerializedForm(ParametersValue obj) {
|
||||||
ImmutableMap.Builder<String,Object> builder =
|
map = obj.params;
|
||||||
ImmutableMap.builder();
|
|
||||||
for (String key : obj)
|
|
||||||
builder.put(key, obj.get(key));
|
|
||||||
this.map = builder.build();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Object readResolve()
|
Object readResolve()
|
||||||
throws java.io.ObjectStreamException {
|
throws java.io.ObjectStreamException {
|
||||||
ParametersValue.Builder builder =
|
ParametersValue.Builder builder =
|
||||||
ParametersValue.make();
|
ParametersValue.make();
|
||||||
for (Map.Entry<String,Object> entry : map.entrySet())
|
builder.params.putAll(map);
|
||||||
builder.set(entry.getKey(), (TypeValue) entry.getValue());
|
|
||||||
return builder.get();
|
return builder.get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,10 @@ public final class StylesValue
|
||||||
extends AbstractDictionaryObject.AbstractBuilder
|
extends AbstractDictionaryObject.AbstractBuilder
|
||||||
<String, StylesValue, Builder> {
|
<String, StylesValue, Builder> {
|
||||||
|
|
||||||
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method media.
|
* Method media.
|
||||||
* @param query String
|
* @param query String
|
||||||
|
|
|
@ -30,10 +30,9 @@ import com.ibm.common.activitystreams.ASObject;
|
||||||
import com.ibm.common.activitystreams.LinkValue;
|
import com.ibm.common.activitystreams.LinkValue;
|
||||||
import com.ibm.common.activitystreams.TypeValue;
|
import com.ibm.common.activitystreams.TypeValue;
|
||||||
|
|
||||||
/**
|
|
||||||
*/
|
|
||||||
public final class TypedPayload
|
public final class TypedPayload
|
||||||
extends ASObject {
|
extends ASObject
|
||||||
|
implements ParameterValue {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method makeTypedPayload.
|
* Method makeTypedPayload.
|
||||||
|
@ -62,7 +61,8 @@ public final class TypedPayload
|
||||||
public static final class Builder
|
public static final class Builder
|
||||||
extends ASObject.AbstractBuilder<TypedPayload, Builder> {
|
extends ASObject.AbstractBuilder<TypedPayload, Builder> {
|
||||||
|
|
||||||
private Builder() {
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
objectType("TypedPayload");
|
objectType("TypedPayload");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,19 +21,16 @@
|
||||||
*/
|
*/
|
||||||
package com.ibm.common.activitystreams.actions;
|
package com.ibm.common.activitystreams.actions;
|
||||||
|
|
||||||
import static com.ibm.common.activitystreams.Makers.type;
|
|
||||||
import static com.ibm.common.activitystreams.Makers.object;
|
|
||||||
|
|
||||||
import java.io.ObjectStreamException;
|
import java.io.ObjectStreamException;
|
||||||
|
|
||||||
import com.google.common.base.Supplier;
|
import com.google.common.base.Supplier;
|
||||||
import com.ibm.common.activitystreams.ASObject;
|
import com.ibm.common.activitystreams.ASObject;
|
||||||
import com.ibm.common.activitystreams.TypeValue;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
public final class UrlTemplate
|
public final class UrlTemplate
|
||||||
extends ASObject {
|
extends ASObject
|
||||||
|
implements ParameterValue {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Method makeUrlTemplate.
|
* Method makeUrlTemplate.
|
||||||
|
@ -51,93 +48,32 @@ public final class UrlTemplate
|
||||||
private final ParametersValue.Builder params =
|
private final ParametersValue.Builder params =
|
||||||
ParametersValue.make();
|
ParametersValue.make();
|
||||||
|
|
||||||
private Builder() {
|
public Builder() {
|
||||||
|
writeUsing(ActionMakers.io);
|
||||||
objectType("UrlTemplate");
|
objectType("UrlTemplate");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method template.
|
|
||||||
* @param template String
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder template(String template) {
|
public Builder template(String template) {
|
||||||
set("template", template);
|
set("template", template);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param iri String
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(String name, String iri) {
|
public Builder parameter(String name, String iri) {
|
||||||
params.set(name, type(iri));
|
params.param(name, iri);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param iri String
|
|
||||||
* @param required boolean
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
public Builder parameter(
|
||||||
String name,
|
String name,
|
||||||
String iri,
|
ParameterValue parameter) {
|
||||||
boolean required) {
|
params.param(name, parameter);
|
||||||
return parameter(
|
|
||||||
name,
|
|
||||||
object()
|
|
||||||
.id(iri)
|
|
||||||
.set("required", required));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param iri String
|
|
||||||
* @param required boolean
|
|
||||||
* @param value Object
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
|
||||||
String name,
|
|
||||||
String iri,
|
|
||||||
boolean required,
|
|
||||||
Object value) {
|
|
||||||
return parameter(
|
|
||||||
name,
|
|
||||||
object()
|
|
||||||
.id(iri)
|
|
||||||
.set("required", required)
|
|
||||||
.set("value", value));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param lv TypeValue
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
|
||||||
String name,
|
|
||||||
TypeValue lv) {
|
|
||||||
params.set(name, lv);
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method parameter.
|
|
||||||
* @param name String
|
|
||||||
* @param lv Supplier<? extends TypeValue>
|
|
||||||
* @return Builder
|
|
||||||
*/
|
|
||||||
public Builder parameter(
|
public Builder parameter(
|
||||||
String name,
|
String name,
|
||||||
Supplier<? extends TypeValue> lv) {
|
Supplier<? extends ParameterValue> parameter) {
|
||||||
return parameter(name, lv.get());
|
return parameter(name, parameter.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -0,0 +1,159 @@
|
||||||
|
package com.ibm.common.activitystreams.actions.test;
|
||||||
|
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.htmlForm;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.io;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.parameter;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.typedPayload;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.urlTemplate;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.embedAction;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.intentAction;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.httpAction;
|
||||||
|
import static com.ibm.common.activitystreams.actions.ActionMakers.styles;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static com.google.common.collect.Iterables.*;
|
||||||
|
|
||||||
|
import com.google.common.net.MediaType;
|
||||||
|
import com.ibm.common.activitystreams.ASObject;
|
||||||
|
import com.ibm.common.activitystreams.LinkValue;
|
||||||
|
import com.ibm.common.activitystreams.LinkValue.SimpleLinkValue;
|
||||||
|
import com.ibm.common.activitystreams.actions.EmbedActionHandler;
|
||||||
|
import com.ibm.common.activitystreams.actions.HtmlForm;
|
||||||
|
import com.ibm.common.activitystreams.actions.HttpActionHandler;
|
||||||
|
import com.ibm.common.activitystreams.actions.IntentActionHandler;
|
||||||
|
import com.ibm.common.activitystreams.actions.Parameter;
|
||||||
|
import com.ibm.common.activitystreams.actions.ParametersValue;
|
||||||
|
import com.ibm.common.activitystreams.actions.StylesValue;
|
||||||
|
import com.ibm.common.activitystreams.actions.TypedPayload;
|
||||||
|
import com.ibm.common.activitystreams.actions.UrlTemplate;
|
||||||
|
|
||||||
|
public final class ActionsTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void roundtripHttpActionHandler() {
|
||||||
|
|
||||||
|
HttpActionHandler hah1 =
|
||||||
|
httpAction()
|
||||||
|
.url("http://example.org")
|
||||||
|
.method("GET")
|
||||||
|
.get();
|
||||||
|
|
||||||
|
HttpActionHandler hah2 =
|
||||||
|
roundTrip(hah1);
|
||||||
|
|
||||||
|
assertEquals("GET", hah2.method());
|
||||||
|
|
||||||
|
Iterable<LinkValue> i = hah2.url();
|
||||||
|
LinkValue lv = getFirst(i,null);
|
||||||
|
assertNotNull(lv);
|
||||||
|
assertTrue(lv instanceof SimpleLinkValue);
|
||||||
|
SimpleLinkValue slv = (SimpleLinkValue) lv;
|
||||||
|
assertEquals("http://example.org", slv.url());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void roundtripIntentActionHandler() {
|
||||||
|
|
||||||
|
IntentActionHandler iah1 =
|
||||||
|
intentAction()
|
||||||
|
.id("urn:example:foo:1")
|
||||||
|
.get();
|
||||||
|
|
||||||
|
IntentActionHandler iah2 =
|
||||||
|
roundTrip(iah1);
|
||||||
|
|
||||||
|
assertEquals("urn:example:foo:1", iah2.id());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void roundtripEmbedActionHandler() {
|
||||||
|
|
||||||
|
EmbedActionHandler eah1 =
|
||||||
|
embedAction()
|
||||||
|
.style(
|
||||||
|
styles()
|
||||||
|
.set("width", "100px")
|
||||||
|
)
|
||||||
|
.get();
|
||||||
|
|
||||||
|
EmbedActionHandler eah2 =
|
||||||
|
roundTrip(eah1);
|
||||||
|
|
||||||
|
Iterable<StylesValue> styles =
|
||||||
|
eah2.styles();
|
||||||
|
StylesValue style =
|
||||||
|
getFirst(styles, null);
|
||||||
|
assertNotNull(style);
|
||||||
|
assertTrue(style.has("width"));
|
||||||
|
assertEquals("100px", style.get("width"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void roundtripHtmlForm() {
|
||||||
|
HtmlForm htmlForm1 =
|
||||||
|
htmlForm()
|
||||||
|
.parameter("foo", parameter().optional())
|
||||||
|
.get();
|
||||||
|
|
||||||
|
HtmlForm htmlForm2 =
|
||||||
|
roundTrip(htmlForm1);
|
||||||
|
|
||||||
|
ParametersValue params =
|
||||||
|
htmlForm2.parameters();
|
||||||
|
assertTrue(params.has("foo"));
|
||||||
|
|
||||||
|
Parameter param = params.get("foo");
|
||||||
|
assertFalse(param.required());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void roundtripTypedValue() {
|
||||||
|
TypedPayload typedPayload1 =
|
||||||
|
typedPayload()
|
||||||
|
.mediaType(MediaType.create("application", "json"))
|
||||||
|
.get();
|
||||||
|
|
||||||
|
TypedPayload typedPayload2 =
|
||||||
|
roundTrip(typedPayload1);
|
||||||
|
|
||||||
|
assertEquals(
|
||||||
|
typedPayload1.mediaType(),
|
||||||
|
typedPayload2.mediaType());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void roundtripUrlTemplate() {
|
||||||
|
UrlTemplate template1 =
|
||||||
|
urlTemplate()
|
||||||
|
.template("http://example.org{/foo}")
|
||||||
|
.parameter("foo", "bar")
|
||||||
|
.get();
|
||||||
|
UrlTemplate template2 =
|
||||||
|
roundTrip(template1);
|
||||||
|
assertEquals(
|
||||||
|
template1.template(),
|
||||||
|
template2.template());
|
||||||
|
ParametersValue value =
|
||||||
|
template2.parameters();
|
||||||
|
assertTrue(value.has("foo"));
|
||||||
|
}
|
||||||
|
|
||||||
|
private <T extends ASObject>T roundTrip(T writable) {
|
||||||
|
ByteArrayOutputStream out =
|
||||||
|
new ByteArrayOutputStream();
|
||||||
|
writable.writeTo(out,io);
|
||||||
|
ByteArrayInputStream in =
|
||||||
|
new ByteArrayInputStream(out.toByteArray());
|
||||||
|
return io.readAs(in);
|
||||||
|
}
|
||||||
|
}
|
|
@ -23,7 +23,6 @@ package com.ibm.common.activitystreams;
|
||||||
|
|
||||||
import static com.google.common.base.Enums.getIfPresent;
|
import static com.google.common.base.Enums.getIfPresent;
|
||||||
import static com.google.common.base.Preconditions.checkArgument;
|
import static com.google.common.base.Preconditions.checkArgument;
|
||||||
import static com.google.common.base.Preconditions.checkNotNull;
|
|
||||||
import static com.google.common.base.Throwables.propagate;
|
import static com.google.common.base.Throwables.propagate;
|
||||||
import static com.google.common.collect.ImmutableList.of;
|
import static com.google.common.collect.ImmutableList.of;
|
||||||
import static com.google.common.collect.Iterables.filter;
|
import static com.google.common.collect.Iterables.filter;
|
||||||
|
@ -45,6 +44,7 @@ import static com.ibm.common.activitystreams.util.Converters.toInterval;
|
||||||
import static com.ibm.common.activitystreams.util.Converters.toLong;
|
import static com.ibm.common.activitystreams.util.Converters.toLong;
|
||||||
import static com.ibm.common.activitystreams.util.Converters.toPeriod;
|
import static com.ibm.common.activitystreams.util.Converters.toPeriod;
|
||||||
import static com.ibm.common.activitystreams.util.Converters.toShort;
|
import static com.ibm.common.activitystreams.util.Converters.toShort;
|
||||||
|
import static com.ibm.common.activitystreams.util.Util.DEFAULT_LOCALE;
|
||||||
import static java.lang.Math.ceil;
|
import static java.lang.Math.ceil;
|
||||||
import static java.lang.Math.floor;
|
import static java.lang.Math.floor;
|
||||||
import static org.joda.time.DateTimeZone.UTC;
|
import static org.joda.time.DateTimeZone.UTC;
|
||||||
|
@ -53,7 +53,6 @@ import static org.joda.time.Duration.standardSeconds;
|
||||||
import java.io.ObjectStreamException;
|
import java.io.ObjectStreamException;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
@ -145,18 +144,6 @@ public class ASObject
|
||||||
return l;
|
return l;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method convLocale.
|
|
||||||
* @param locale Locale
|
|
||||||
* @return String
|
|
||||||
**/
|
|
||||||
private static String convLocale(Locale locale) {
|
|
||||||
return checkNotNull(locale).toString().replaceAll("_", "-");
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final String DEFAULT_LOCALE =
|
|
||||||
convLocale(Locale.getDefault());
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Abstract base builder for ASObject instances.
|
* Abstract base builder for ASObject instances.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -94,4 +94,5 @@ public interface Writable {
|
||||||
* @return Future<?>
|
* @return Future<?>
|
||||||
*/
|
*/
|
||||||
Future<?> writeTo(Writer out, IO io, ExecutorService executor);
|
Future<?> writeTo(Writer out, IO io, ExecutorService executor);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -237,7 +237,29 @@ public final class GsonWrapper {
|
||||||
GsonBuilder gson = new GsonBuilder()
|
GsonBuilder gson = new GsonBuilder()
|
||||||
.registerTypeHierarchyAdapter(TypeValue.class, new TypeValueAdapter(schema))
|
.registerTypeHierarchyAdapter(TypeValue.class, new TypeValueAdapter(schema))
|
||||||
.registerTypeHierarchyAdapter(LinkValue.class, new LinkValueAdapter(schema))
|
.registerTypeHierarchyAdapter(LinkValue.class, new LinkValueAdapter(schema))
|
||||||
.registerTypeHierarchyAdapter(Iterable.class, ITERABLE);
|
.registerTypeHierarchyAdapter(Iterable.class, ITERABLE)
|
||||||
|
.registerTypeHierarchyAdapter(ASObject.class, base)
|
||||||
|
.registerTypeHierarchyAdapter(Collection.class, base)
|
||||||
|
.registerTypeHierarchyAdapter(Activity.class, base)
|
||||||
|
.registerTypeHierarchyAdapter(NLV.class, NLV)
|
||||||
|
.registerTypeHierarchyAdapter(ActionsValue.class, ACTIONS)
|
||||||
|
.registerTypeHierarchyAdapter(Optional.class, OPTIONAL)
|
||||||
|
.registerTypeHierarchyAdapter(Range.class, RANGE)
|
||||||
|
.registerTypeHierarchyAdapter(Table.class, TABLE)
|
||||||
|
.registerTypeHierarchyAdapter(LazilyParsedNumber.class, NUMBER)
|
||||||
|
.registerTypeHierarchyAdapter(LazilyParsedNumberComparable.class, NUMBER)
|
||||||
|
.registerTypeHierarchyAdapter(ReadableDuration.class, DURATION)
|
||||||
|
.registerTypeHierarchyAdapter(ReadablePeriod.class, PERIOD)
|
||||||
|
.registerTypeHierarchyAdapter(ReadableInterval.class, INTERVAL)
|
||||||
|
.registerTypeAdapter(
|
||||||
|
Activity.Status.class,
|
||||||
|
forEnum(
|
||||||
|
Activity.Status.class,
|
||||||
|
Activity.Status.OTHER))
|
||||||
|
.registerTypeAdapter(Date.class, DATE)
|
||||||
|
.registerTypeAdapter(DateTime.class, DATETIME)
|
||||||
|
.registerTypeAdapter(MediaType.class, MIMETYPE)
|
||||||
|
.registerTypeHierarchyAdapter(Multimap.class, MULTIMAP);
|
||||||
|
|
||||||
for (AdapterEntry<?> entry : adapters) {
|
for (AdapterEntry<?> entry : adapters) {
|
||||||
if (entry.hier)
|
if (entry.hier)
|
||||||
|
@ -252,30 +274,8 @@ public final class GsonWrapper {
|
||||||
entry.adapter:base);
|
entry.adapter:base);
|
||||||
}
|
}
|
||||||
|
|
||||||
return gson
|
return gson;
|
||||||
.registerTypeHierarchyAdapter(NLV.class, NLV)
|
|
||||||
.registerTypeHierarchyAdapter(ActionsValue.class, ACTIONS)
|
|
||||||
.registerTypeHierarchyAdapter(Optional.class, OPTIONAL)
|
|
||||||
.registerTypeHierarchyAdapter(Range.class, RANGE)
|
|
||||||
.registerTypeHierarchyAdapter(Table.class, TABLE)
|
|
||||||
.registerTypeHierarchyAdapter(LazilyParsedNumber.class, NUMBER)
|
|
||||||
.registerTypeHierarchyAdapter(LazilyParsedNumberComparable.class, NUMBER)
|
|
||||||
.registerTypeHierarchyAdapter(ASObject.class, base)
|
|
||||||
.registerTypeHierarchyAdapter(Collection.class, base)
|
|
||||||
.registerTypeHierarchyAdapter(Activity.class, base)
|
|
||||||
.registerTypeHierarchyAdapter(ReadableDuration.class, DURATION)
|
|
||||||
.registerTypeHierarchyAdapter(ReadablePeriod.class, PERIOD)
|
|
||||||
.registerTypeHierarchyAdapter(ReadableInterval.class, INTERVAL)
|
|
||||||
.registerTypeAdapter(
|
|
||||||
Activity.Status.class,
|
|
||||||
forEnum(
|
|
||||||
Activity.Status.class,
|
|
||||||
Activity.Status.OTHER))
|
|
||||||
.registerTypeAdapter(Date.class, DATE)
|
|
||||||
.registerTypeAdapter(DateTime.class, DATETIME)
|
|
||||||
.registerTypeAdapter(MediaType.class, MIMETYPE)
|
|
||||||
.registerTypeHierarchyAdapter(Multimap.class, MULTIMAP)
|
|
||||||
;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
package com.ibm.common.activitystreams.util;
|
||||||
|
|
||||||
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
public final class Util {
|
||||||
|
|
||||||
|
private Util() {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method convLocale.
|
||||||
|
* @param locale Locale
|
||||||
|
* @return String
|
||||||
|
**/
|
||||||
|
public static String convLocale(Locale locale) {
|
||||||
|
return checkNotNull(locale).toString().replaceAll("_", "-");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static final String DEFAULT_LOCALE =
|
||||||
|
convLocale(Locale.getDefault());
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue