/*
* Copyright 2010-2012 Amazon Technologies, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://aws.amazon.com/apache2.0
*
* This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES
* OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and
* limitations under the License.
*/
package com.amazonaws.eclipse.databinding;
import org.eclipse.core.databinding.validation.IValidator;
import org.eclipse.core.databinding.validation.ValidationStatus;
import org.eclipse.core.runtime.IStatus;
import com.fasterxml.jackson.databind.ObjectMapper;
/**
* Simple IValidator implementation that returns an OK status if the String
* is in valid JSON format, otherwise it returns a validation status with
* the message specified in the constructor.
*/
public class JsonStringValidator implements IValidator {
private final String message;
private final boolean allowEmptyString;
private static final ObjectMapper mapper = new ObjectMapper();
public JsonStringValidator(String message, boolean allowEmptyString) {
this.message = message;
this.allowEmptyString = allowEmptyString;
}
public IStatus validate(Object value) {
String s = (String)value;
if (s == null || s.isEmpty()) {
return allowEmptyString ? ValidationStatus.ok() : ValidationStatus
.error(message);
}
try {
mapper.readTree(s);
} catch (Exception e) {
return ValidationStatus.error(message);
}
return ValidationStatus.ok();
}
}