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

org.teiid.spring.views.JsonTableView Maven / Gradle / Ivy

There is a newer version: 1.7.2
Show newest version
/*
 * Copyright 2012-2017 the original author or authors.
 *
 * 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.teiid.spring.views;

import java.lang.reflect.Field;

import org.hibernate.boot.Metadata;
import org.springframework.context.ApplicationContext;
import org.teiid.metadata.Column;
import org.teiid.metadata.MetadataFactory;
import org.teiid.metadata.Table;
import org.teiid.spring.annotations.JsonTable;
import org.teiid.spring.annotations.RestConfiguration;
import org.teiid.spring.common.ExternalSource;
import org.teiid.spring.data.BaseConnectionFactory;

import com.fasterxml.jackson.annotation.JsonProperty;

public class JsonTableView extends ViewBuilder {
    private StringBuilder columndef = new StringBuilder();
    private StringBuilder columns = new StringBuilder();

    public JsonTableView(Metadata metadata) {
        super(metadata);
    }

    @Override
    void onFinish(Table view, MetadataFactory mf, Class entityClazz, JsonTable annotation,
            ApplicationContext context) {
        String source = annotation.source();
        String endpoint = annotation.endpoint();

        String translator = "file";
        BaseConnectionFactory bean = (BaseConnectionFactory)context.getBean(source);
        if (bean != null) {
            translator = bean.getTranslatorName();
        }

        view.setSupportsUpdate(false);

        StringBuilder sb = new StringBuilder();
        sb.append("SELECT \n");
        sb.append(columns.toString()).append("\n");
        sb.append("FROM (");
        if (translator.equalsIgnoreCase(ExternalSource.FILE.getTranslatorName())) {
            sb.append("EXEC ").append(source).append(".getFiles('").append(endpoint).append("')");
        } else if (translator.equalsIgnoreCase(ExternalSource.REST.getTranslatorName())) {
            generateRestProcedure(entityClazz, source, endpoint, sb);
        } else if (translator.equalsIgnoreCase(ExternalSource.AMAZONS3.getTranslatorName())) {
            sb.append("EXEC ").append(source).append(".getTextFile('").append(endpoint).append("')");
        } else {
            throw new IllegalStateException("Source type '" + annotation.source() + " not supported on JsonTable "
                    + view.getName() + ". Only \"file\" and \"rest\" are supported");
        }
        sb.append(") AS f, ").append("\n");

        String root = annotation.root();
        root = "/response" + root;
        if (annotation.rootIsArray()) {
            root = "/response" + root;
        }
        if (root.endsWith("/")) {
            root = root.substring(0, root.lastIndexOf('/'));
        }

        if (translator.equals(ExternalSource.FILE.getTranslatorName())) {
            sb.append("XMLTABLE('").append(root).append("' PASSING JSONTOXML('response', f.file) ");
        } else if (translator.equalsIgnoreCase(ExternalSource.REST.getTranslatorName())){
            sb.append("XMLTABLE('").append(root).append("' PASSING JSONTOXML('response', f.result) ");
        } else if (translator.equalsIgnoreCase(ExternalSource.AMAZONS3.getTranslatorName())) {
            sb.append("XMLTABLE('").append(root).append("' PASSING JSONTOXML('response', f.file) ");
        }
        sb.append("COLUMNS ").append(columndef.toString());
        sb.append(") AS jt");

        view.setSelectTransformation(sb.toString());
    }

    static void generateRestProcedure(Class entityClazz, String source, String endPoint, StringBuilder sb) {
        if (endPoint.startsWith("http")) {
            RestConfiguration config = entityClazz.getAnnotation(RestConfiguration.class);
            String method = (config == null) ? "GET" : config.method();
            String headers = (config == null) ? null : config.headersBean();
            boolean streaming = (config == null) ? true : config.stream();
            String body = (config == null) ? null : config.bodyBean();
            sb.append("EXEC ").append(source).append(".invokeHttp(action=>'").append(method).append("', ");
            sb.append("endpoint=>'").append(endPoint).append("', ");
            if (headers != null && !headers.isEmpty()) {
                sb.append("headers=>jsonObject('").append(headers).append("' as \"T-Spring-Bean\"), ");
            }
            if (body != null && !body.isEmpty()) {
                sb.append("body=>'").append(body).append("', ");
            }
            sb.append("stream=>'").append(Boolean.toString(streaming)).append("'");
            sb.append(")");
        } else {
            sb.append("EXEC ").append(source).append(".springHttp('").append(endPoint).append("')");
        }
    }



    @Override
    void onColumnCreate(Table view, Column column, MetadataFactory mf, Field field, String parent, boolean last,
            JsonTable annotation) {

        JsonTable colAnnotation = null;
        if (field != null) {
            colAnnotation = field.getAnnotation(JsonTable.class);
        }

        this.columns.append("jt.").append(column.getName());
        if (!last) {
            this.columns.append(", ");
        } else {
            this.columns.append(" ");
        }

        this.columndef.append(column.getName());

        if (colAnnotation != null && colAnnotation.ordinal()) {
            columndef.append(" FOR ORDINALITY");
        } else {
            columndef.append(" ").append(column.getRuntimeType());
        }

        JsonProperty jsonProperty = field == null ? null : field.getAnnotation(JsonProperty.class);
        if (jsonProperty != null) {
            columndef.append(" PATH '").append(jsonProperty.value()).append("'");
        } else if (parent != null) {
            columndef.append(" PATH '").append(parent).append("/").append(column.getName()).append("'");
        } if (field == null) {
            // this is implicit join, where the array item does not have an id, but parent's id is its id
            columndef.append(" PATH '").append("../").append(column.getName()).append("'");
        }

        if (!last) {
            this.columndef.append(", ");
        } else {
            this.columndef.append(" ");
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy