/** * Copyright © 2006-2016 Web Cohesion (info@webcohesion.com) * * 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 com.webcohesion.enunciate.modules.spring_web.api.impl; import com.webcohesion.enunciate.api.Styles; import com.webcohesion.enunciate.api.datatype.BaseTypeFormat; import com.webcohesion.enunciate.api.resources.Parameter; import com.webcohesion.enunciate.javac.javadoc.JavaDoc; import com.webcohesion.enunciate.modules.spring_web.model.RequestParameter; import com.webcohesion.enunciate.modules.spring_web.model.ResourceParameterConstraints; import com.webcohesion.enunciate.util.BeanValidationUtils; import org.springframework.format.annotation.DateTimeFormat; import javax.lang.model.element.AnnotationMirror; import javax.lang.model.element.Element; import java.lang.annotation.Annotation; import java.util.Collections; import java.util.Iterator; import java.util.Map; import java.util.Set; /** * @author Ryan Heaton */ public class ParameterImpl implements Parameter { private final RequestParameter param; public ParameterImpl(RequestParameter param) { this.param = param; } @Override public String getName() { return this.param.getParameterName(); } @Override public String getDescription() { return this.param.getDocValue(); } @Override public String getTypeLabel() { return this.param.getTypeName(); } @Override public String getTypeName() { return this.param.getDataType().name().toLowerCase(); } @Override public String getDefaultValue() { return this.param.getDefaultValue(); } @Override public String getConstraints() { String validationConstraints = BeanValidationUtils.describeConstraints(this.param, this.param.isRequired()); String dateTimeFormatDescription = describeDateTimeFormat(this.param); if (validationConstraints != null || dateTimeFormatDescription != null) { StringBuilder constraints = new StringBuilder(); if (dateTimeFormatDescription != null) { constraints.append(dateTimeFormatDescription); if (validationConstraints != null) { constraints.append(", "); } } if (validationConstraints != null) { constraints.append(validationConstraints); } return constraints.toString(); } else { ResourceParameterConstraints constraints = this.param.getConstraints(); if (constraints != null && constraints.getType() != null) { switch (constraints.getType()) { case ENUMERATION: StringBuilder builder = new StringBuilder(); Iterator<String> it = ((ResourceParameterConstraints.Enumeration) constraints).getValues().iterator(); while (it.hasNext()) { String next = it.next(); builder.append('"').append(next).append('"'); if (it.hasNext()) { builder.append(" or "); } } return builder.toString(); case PRIMITIVE: return ((ResourceParameterConstraints.Primitive) constraints).getKind().name().toLowerCase(); case REGEX: return "regex: " + ((ResourceParameterConstraints.Regex) constraints).getRegex(); default: //fall through. } } return null; } } private static String describeDateTimeFormat(Element element) { DateTimeFormat dateFormat = element.getAnnotation(DateTimeFormat.class); String description = null; if (dateFormat != null) { if (!"".equals(dateFormat.pattern())) { description = "date (" + dateFormat.pattern() + ")"; } else if (dateFormat.iso() != DateTimeFormat.ISO.NONE) { switch (dateFormat.iso()) { case DATE: description = "date (yyyy-MM-dd)"; break; case TIME: description = "time (HH:mm:ss.SSSZ)"; break; case DATE_TIME: description = "date+time (yyyy-MM-dd'T'HH:mm:ss.SSSZ)"; break; } } } return description; } @Override public Set<String> getConstraintValues() { ResourceParameterConstraints constraints = this.param.getConstraints(); if (constraints != null && constraints.getType() != null) { switch (constraints.getType()) { case UNBOUND_STRING: return null; case ENUMERATION: return ((ResourceParameterConstraints.Enumeration) constraints).getValues(); case PRIMITIVE: return null; case REGEX: return null; } } return null; } @Override public <A extends Annotation> A getAnnotation(Class<A> annotationType) { return this.param.getAnnotation(annotationType); } @Override public Map<String, AnnotationMirror> getAnnotations() { return this.param.getAnnotations(); } @Override public JavaDoc getJavaDoc() { return this.param.getJavaDoc(); } @Override public boolean isMultivalued() { return this.param.isMultivalued(); } @Override public Set<String> getStyles() { return Styles.gatherStyles(this.param, Collections.<String, String>emptyMap()); } @Override public BaseTypeFormat getTypeFormat() { return null; } }