All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.atlasmap.json.module.JsonValidationService Maven / Gradle / Ivy

There is a newer version: 2.5.2
Show newest version
/**
 * Copyright (C) 2017 Red Hat, 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://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License 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 io.atlasmap.json.module; import java.util.HashMap; import java.util.List; import java.util.Map; import io.atlasmap.core.validate.BaseModuleValidationService; import io.atlasmap.json.v2.JsonField; import io.atlasmap.spi.AtlasConversionService; import io.atlasmap.spi.AtlasFieldActionService; import io.atlasmap.spi.AtlasModuleDetail; import io.atlasmap.spi.AtlasValidator; import io.atlasmap.spi.FieldDirection; import io.atlasmap.v2.Validation; import io.atlasmap.v2.ValidationScope; import io.atlasmap.v2.ValidationStatus; import io.atlasmap.validators.NonNullValidator; public class JsonValidationService extends BaseModuleValidationService { private static Map validatorMap = new HashMap<>(); private AtlasModuleDetail moduleDetail = JsonModule.class.getAnnotation(AtlasModuleDetail.class); public JsonValidationService(AtlasConversionService conversionService, AtlasFieldActionService fieldActionService) { super(conversionService, fieldActionService); init(); } public void init() { NonNullValidator javaFilePathNonNullValidator = new NonNullValidator(ValidationScope.MAPPING, "The path element must not be null nor empty"); NonNullValidator inputFieldTypeNonNullValidator = new NonNullValidator(ValidationScope.MAPPING, "Field type should not be null nor empty"); NonNullValidator outputFieldTypeNonNullValidator = new NonNullValidator(ValidationScope.MAPPING, "Field type should not be null nor empty"); NonNullValidator fieldTypeNonNullValidator = new NonNullValidator(ValidationScope.MAPPING, "Filed type should not be null nor empty"); validatorMap.put("json.field.type.not.null", fieldTypeNonNullValidator); validatorMap.put("json.field.path.not.null", javaFilePathNonNullValidator); validatorMap.put("input.field.type.not.null", inputFieldTypeNonNullValidator); validatorMap.put("output.field.type.not.null", outputFieldTypeNonNullValidator); } public void destroy() { validatorMap.clear(); } @Override protected AtlasModuleDetail getModuleDetail() { return moduleDetail; } @Override protected Class getFieldType() { return JsonField.class; } @Override protected String getModuleFieldName(JsonField field) { return field.getName() != null ? field.getName() : field.getPath(); } @Override protected void validateModuleField(String mappingId, JsonField field, FieldDirection direction, List validations) { // TODO check that it is a valid type on the AtlasContext validatorMap.get("json.field.type.not.null").validate(field, validations, mappingId, ValidationStatus.WARN); if (field.getPath() == null) { validatorMap.get("json.field.path.not.null").validate(field.getPath(), validations, mappingId); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy