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

org.jsonschema2pojo.rules.FormatRule Maven / Gradle / Ivy

/**
 * Copyright © 2010-2020 Nokia
 *
 * 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 org.jsonschema2pojo.rules;

import static java.lang.String.*;
import static org.apache.commons.lang.StringUtils.*;

import java.net.URI;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
import java.util.regex.Pattern;

import org.apache.commons.lang3.ClassUtils;
import org.joda.time.DateTime;
import org.joda.time.LocalDate;
import org.joda.time.LocalTime;
import org.jsonschema2pojo.GenerationConfig;
import org.jsonschema2pojo.Schema;
import org.jsonschema2pojo.exception.GenerationException;

import com.fasterxml.jackson.databind.JsonNode;
import com.sun.codemodel.JType;

/**
 * Applies the "format" schema rule.
 *
 * @see http://tools.ietf.org/html/draft-zyp-json-schema-03#section-5.23
 */
public class FormatRule implements Rule {

    public static String ISO_8601_DATE_FORMAT = "yyyy-MM-dd";
    public static String ISO_8601_TIME_FORMAT = "HH:mm:ss.SSS";
    public static String ISO_8601_DATETIME_FORMAT = "yyyy-MM-dd'T'HH:mm:ss.SSSXXX";

    private final RuleFactory ruleFactory;
    private final Map> formatTypeMapping;

    protected FormatRule(RuleFactory ruleFactory) {
        this.ruleFactory = ruleFactory;
        this.formatTypeMapping = getFormatTypeMapping(ruleFactory.getGenerationConfig());
    }

    /**
     * Applies this schema rule to take the required code generation steps.
     * 

* This rule maps format values to Java types. By default: *

    *
  • "format":"date-time" => {@link java.util.Date} or {@link org.joda.time.DateTime} (if config useJodaDates is set) *
  • "format":"date" => {@link String} or {@link org.joda.time.LocalDate} (if config useJodaLocalDates is set) *
  • "format":"time" => {@link String} or {@link org.joda.time.LocalTime} (if config useJodaLocalTimes is set) *
  • "format":"utc-millisec" => long *
  • "format":"regex" => {@link java.util.regex.Pattern} *
  • "format":"color" => {@link String} *
  • "format":"style" => {@link String} *
  • "format":"phone" => {@link String} *
  • "format":"uri" => {@link java.net.URI} *
  • "format":"email" => {@link String} *
  • "format":"ip-address" => {@link String} *
  • "format":"ipv6" => {@link String} *
  • "format":"host-name" => {@link String} *
  • "format":"uuid" => {@link java.util.UUID} *
  • other (unrecognised format) => baseType *
* * @param nodeName * the name of the node to which this format is applied * @param node * the format node * @param parent * the parent node * @param baseType * the type which which is being formatted e.g. for * { "type" : "string", "format" : "uri" } the * baseType would be java.lang.String * @return the Java type that is appropriate for the format value */ @Override public JType apply(String nodeName, JsonNode node, JsonNode parent, JType baseType, Schema schema) { Class type = getType(node.asText()); if (type != null) { JType jtype = baseType.owner()._ref(type); if (ruleFactory.getGenerationConfig().isUsePrimitives()) { jtype = jtype.unboxify(); } return jtype; } else { return baseType; } } private Class getType(String format) { return formatTypeMapping.getOrDefault(format, null); } private static Map> getFormatTypeMapping(GenerationConfig config) { Map> mapping = new HashMap<>(14); mapping.put("date-time", getDateTimeType(config)); mapping.put("date", getDateType(config)); mapping.put("time", getTimeType(config)); mapping.put("utc-millisec", Long.class); mapping.put("regex", Pattern.class); mapping.put("color", String.class); mapping.put("style", String.class); mapping.put("phone", String.class); mapping.put("uri", URI.class); mapping.put("email", String.class); mapping.put("ip-address", String.class); mapping.put("ipv6", String.class); mapping.put("host-name", String.class); mapping.put("uuid", UUID.class); for (Map.Entry override : config.getFormatTypeMapping().entrySet()) { String format = override.getKey(); Class type = tryLoadType(override.getValue(), format); if (type != null) { mapping.put(format, type); } } return mapping; } private static Class getDateTimeType(GenerationConfig config) { Class type = tryLoadType(config.getDateTimeType(), "data-time"); if (type != null) { return type; } return config.isUseJodaDates() ? DateTime.class : Date.class; } private static Class getDateType(GenerationConfig config) { Class type = tryLoadType(config.getDateType(), "data"); if (type != null) { return type; } return config.isUseJodaLocalDates() ? LocalDate.class : String.class; } private static Class getTimeType(GenerationConfig config) { Class type = tryLoadType(config.getTimeType(), "time"); if (type != null) { return type; } return config.isUseJodaLocalTimes() ? LocalTime.class : String.class; } private static Class tryLoadType(String typeName, String format) { if (!isEmpty(typeName)) { try { Class type = ClassUtils.getClass(Thread.currentThread().getContextClassLoader(), typeName); return type; } catch (ClassNotFoundException e) { throw new GenerationException(format("could not load java type %s for %s", typeName, format), e); } } return null; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy