Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   * See the COPYRIGHT.txt file distributed with this work for information
   * regarding copyright ownership.  Some portions may be licensed
   * to Red Hat, Inc. under one or more contributor license agreements.
   *
   * This library is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
  * version 2.1 of the License, or (at your option) any later version.
  *
  * This library is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with this library; if not, write to the Free Software
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  * 02110-1301 USA.
  */
 package org.teiid.olingo;
 
 import java.util.List;
 import java.util.Map;
 
 import  org.apache.olingo.commons.api.edm.EdmPrimitiveTypeKind;
 import  org.apache.olingo.commons.api.edm.FullQualifiedName;
 import  org.apache.olingo.commons.api.edm.Target;
 import  org.apache.olingo.server.api.edm.provider.Action;
 import  org.apache.olingo.server.api.edm.provider.ActionImport;
 import  org.apache.olingo.server.api.edm.provider.ComplexType;
 import  org.apache.olingo.server.api.edm.provider.EntityContainer;
 import  org.apache.olingo.server.api.edm.provider.EntitySet;
 import  org.apache.olingo.server.api.edm.provider.EntityType;
 import  org.apache.olingo.server.api.edm.provider.Function;
 import  org.apache.olingo.server.api.edm.provider.FunctionImport;
 import  org.apache.olingo.server.api.edm.provider.NavigationProperty;
 import  org.apache.olingo.server.api.edm.provider.NavigationPropertyBinding;
 import  org.apache.olingo.server.api.edm.provider.Parameter;
 import  org.apache.olingo.server.api.edm.provider.Property;
 import  org.apache.olingo.server.api.edm.provider.PropertyRef;
 import  org.apache.olingo.server.api.edm.provider.ReferentialConstraint;
 import  org.apache.olingo.server.api.edm.provider.ReturnType;
 
 public class OData4EntitySchemaBuilder {
 
     public static org.apache.olingo.server.api.edm.provider.Schema buildMetadata(org.teiid.metadata.Schema teiidSchema) {
         try {
             org.apache.olingo.server.api.edm.provider.Schema edmSchema = new org.apache.olingo.server.api.edm.provider.Schema();
             buildEntityTypes(teiidSchemaedmSchema);
             buildProcedures(teiidSchemaedmSchema);
             return edmSchema;
         } catch (Exception e) {
             throw new TeiidRuntimeException(e);
         }
     }
 
     static EntitySet findEntitySet(org.apache.olingo.server.api.edm.provider.Schema edmSchemaString enitityName) {
         EntityContainer entityContainter = edmSchema.getEntityContainer();
         for (EntitySet entitySet : entityContainter.getEntitySets()) {
             if (entitySet.getName().equalsIgnoreCase(enitityName)) {
                 return entitySet;
             }
         }
         return null;
     }
 
     static org.apache.olingo.server.api.edm.provider.Schema findSchema(Map<String, org.apache.olingo.server.api.edm.provider.Schema> edmSchemasString schemaName) {
         return edmSchemas.get(schemaName);
     }
 
     static EntityType findEntityType(Map<String, org.apache.olingo.server.api.edm.provider.Schema> edmSchemasString schemaNameString enitityName) {
         org.apache.olingo.server.api.edm.provider.Schema schema = findSchema(edmSchemasschemaName);
         if (schema != null) {
             for (EntityType type : schema.getEntityTypes()) {
                 if (type.getName().equalsIgnoreCase(enitityName)) {
                     return type;
                 }
             }
         }
         return null;
     }
 
     static EntityContainer findEntityContainer(Map<String, org.apache.olingo.server.api.edm.provider.Schema> edmSchemasString schemaName) {
        org.apache.olingo.server.api.edm.provider.Schema schema = edmSchemas.get(schemaName);
        return schema.getEntityContainer();
    }
    public static void buildEntityTypes(Schema schema, org.apache.olingo.server.api.edm.provider.Schema edmSchema) {
        List<EntitySet> entitySets = new ArrayList<EntitySet>();
        List<EntityType> entityTypes = new ArrayList<EntityType>();
        for (Table table : schema.getTables().values()) {
            // skip if the table does not have the PK or unique
            KeyRecord primaryKey = table.getPrimaryKey();
            List<KeyRecorduniques = table.getUniqueKeys();
            if (primaryKey == null && uniques.isEmpty()) {
                LogManager.logDetail(.,..gs(..,table.getFullName()));
                continue;
            }
            String entityTypeName = table.getName();
            EntityType entityType = new EntityType().setName(entityTypeName);
            // adding properties
            List<Property> properties = new ArrayList<Property>();
            for (Column c : table.getColumns()) {
                properties.add(buildProperty(c));
            }
            entityType.setProperties(properties);
            if (hasStream(properties)) {
                entityType.setHasStream(true);
            }
            // set keys
            ArrayList<PropertyRef> keyProps = new ArrayList<PropertyRef>();
            if (primaryKey != null) {
                for (Column c : primaryKey.getColumns()) {
                    keyProps.add(new PropertyRef().setPropertyName(c.getName()));
                }
            } else {
                for (Column c : uniques.get(0).getColumns()) {
                    keyProps.add(new PropertyRef().setPropertyName(c.getName()));
                }
            }
            entityType.setKey(keyProps);
            // entity set one for one entity type
            EntitySet entitySet = new EntitySet()
                    .setName(table.getName())
                    .setType(new FullQualifiedName(schema.getName(), table.getName()))
                    .setIncludeInServiceDocument(true);
            buildNavigationProperties(tableentityTypeentitySet);
            // add entity types for entity schema
            entityTypes.add(entityType);
            entitySets.add(entitySet);
        }
        // entity container is holder entity sets, association sets, function
        // imports
        EntityContainer entityContainer = new EntityContainer().setName(schema.getName()).setEntitySets(entitySets);
        // build entity schema
        edmSchema.setNamespace(schema.getName()).setAlias(schema.getName())
                .setEntityTypes(entityTypes)
                .setEntityContainer(entityContainer);
    }
    private static boolean hasStream(List<Property> properties) {
        for (Property p : properties) {
            if (p.getType().equals(EdmPrimitiveTypeKind.Binary.getFullQualifiedName())) {
                return true;
            }
        }
        return false;
    }
    private static Property buildProperty(Column c) {
        Property property = new Property()
                .setName(c.getName())
                .setType(ODataTypeManager.odataType(c.getRuntimeType()).getFullQualifiedName())
                .setNullable(c.getNullType() == .);
        if (DataTypeManager.isArrayType(c.getRuntimeType())) {
            property.setCollection(true);
        }
            property.setMaxLength(c.getLength()).setUnicode(true);
        } else if (c.getRuntimeType().equals(
                ..)
                || c.getRuntimeType().equals(..)
                || c.getRuntimeType().equals(..)) {
            property.setPrecision(c.getPrecision());
            property.setScale(c.getScale());
        } else {
            if (c.getDefaultValue() != null) {
                property.setDefaultValue(c.getDefaultValue());
            }
        }
        return property;
    }
    private static void buildNavigationProperties(Table table,
            EntityType entityType, EntitySet entitySet) {
        // skip if the table does not have the PK or unique
        KeyRecord primaryKey = table.getPrimaryKey();
        List<KeyRecorduniques = table.getUniqueKeys();
        if (primaryKey == null && uniques.isEmpty()) {
            return;
        }
        ArrayList<NavigationProperty> navigationProperties = new ArrayList<NavigationProperty>();
        ArrayList<NavigationPropertyBinding> navigationBindingProperties = new ArrayList<NavigationPropertyBinding>();
        // build Associations
        for (ForeignKey fk : table.getForeignKeys()) {
            String refSchemaName = fk.getReferenceKey().getParent().getParent().getName();
            // check to see if fk is part of this table's pk, then it is 1 to 1
            // relation
            boolean onetoone = sameColumnSet(table.getPrimaryKey(), fk);
            NavigationProperty navigaton = new NavigationProperty();
            navigaton.setName(fk.getName()).setType(new FullQualifiedName(refSchemaNamefk.getReferenceTableName()));
            if (!onetoone) {
                navigaton.setCollection(true);
            } else {
                navigaton.setNullable(false);
            }
            NavigationPropertyBinding navigationBinding = new NavigationPropertyBinding();
            navigationBinding.setPath(fk.getName());
            navigationBinding.setTarget(new Target().setTargetName(fk.getReferenceTableName()));
            ArrayList<ReferentialConstraint> constrainsts = new ArrayList<ReferentialConstraint>();
            for (int i = 0; i < fk.getColumns().size(); i++) {
                Column c = fk.getColumns().get(i);
                String refColumn = fk.getReferenceColumns().get(i);
                ReferentialConstraint constraint = new ReferentialConstraint();
                constraint.setProperty(c.getName());
                constraint.setReferencedProperty(refColumn);
            }
            navigaton.setReferentialConstraints(constrainsts);
            navigationProperties.add(navigaton);
            navigationBindingProperties.add(navigationBinding);
        }
        entityType.setNavigationProperties(navigationProperties);
        entitySet.setNavigationPropertyBindings(navigationBindingProperties);
    }
    public static void buildProcedures(Schema schema, org.apache.olingo.server.api.edm.provider.Schema edmSchema) {
        // procedures
        ArrayList<ComplexType> complexTypes = new ArrayList<ComplexType>();
        ArrayList<Function> functions = new ArrayList<Function>();
        ArrayList<FunctionImport> functionImports = new ArrayList<FunctionImport>();
        ArrayList<Action> actions = new ArrayList<Action>();
        ArrayList<ActionImport> actionImports = new ArrayList<ActionImport>();
        for (Procedure proc : schema.getProcedures().values()) {
            if (doesProcedureReturn(proc)) {
                buildFunction(schema.getName(), proccomplexTypesfunctionsfunctionImports);
            }
            else {
                buildAction(schema.getName(), proccomplexTypesactionsactionImports);
            }
        }
        edmSchema.setComplexTypes(complexTypes);
        edmSchema.setFunctions(functions);
        edmSchema.setActions(actions);
        edmSchema.getEntityContainer().setFunctionImports(functionImports);
        edmSchema.getEntityContainer().setActionImports(actionImports);
    }
    private static boolean doesProcedureReturn(Procedure proc) {
        for (ProcedureParameter pp : proc.getParameters()) {
            if (pp.getName().equals("return")) { //$NON-NLS-1$
                return true;
            }
        }
        return false;
    }
    public static void buildFunction(String schemaNameProcedure procArrayList<ComplexType> complexTypesArrayList<Function> functionsArrayList<FunctionImport> functionImports) {
        Function edmFunction = new Function();
        edmFunction.setName(proc.getName());
        edmFunction.setBound(false);
        ArrayList<Parameter> params = new ArrayList<Parameter>();
        for (ProcedureParameter pp : proc.getParameters()) {
            if (pp.getName().equals("return")) { //$NON-NLS-1$
                edmFunction.setReturnType(new ReturnType().setType(ODataTypeManager.odataType(pp.getRuntimeType()).getFullQualifiedName()));
                continue;
            }
            Parameter param = new Parameter();
            param.setName(pp.getName());
            param.setType(ODataTypeManager.odataType(pp.getRuntimeType()).getFullQualifiedName());
            if (DataTypeManager.isArrayType(pp.getRuntimeType())) {
                param.setCollection(true);
            }
            param.setNullable(pp.getNullType() == .);
            params.add(param);
        }
        edmFunction.setParameters(params);
        // add a complex type for return resultset.
        ColumnSet<ProcedurereturnColumns = proc.getResultSet();
        if (returnColumns != null) {
            ComplexType complexType = new ComplexType();
            String entityTypeName = proc.getName() + "_" + returnColumns.getName(); //$NON-NLS-1$
            complexType.setName(entityTypeName);
            ArrayList<Property> props = new ArrayList<Property>();
            for (Column c : returnColumns.getColumns()) {
                props.add(buildProperty(c));
            }
            complexType.setProperties(props);
            complexTypes.add(complexType);
            edmFunction.setReturnType((new ReturnType().setType(new FullQualifiedName(schemaNamecomplexType.getName())).setCollection(true)));
        }
        FunctionImport functionImport = new FunctionImport();
        functionImport.setName(proc.getName()).setFunction(new FullQualifiedName(schemaNameproc.getName()));
        functions.add(edmFunction);
        functionImports.add(functionImport);
    }
    public static void buildAction(String schemaNameProcedure procArrayList<ComplexType> complexTypesArrayList<Action> actionsArrayList<ActionImport> actionImports) {
        Action edmAction = new Action();
        edmAction.setName(proc.getName());
        edmAction.setBound(false);
        ArrayList<Parameter> params = new ArrayList<Parameter>();
        for (ProcedureParameter pp : proc.getParameters()) {
            if (pp.getName().equals("return")) { //$NON-NLS-1$
                edmAction.setReturnType(new ReturnType().setType(ODataTypeManager.odataType(pp.getRuntimeType()).getFullQualifiedName()));
                continue;
            }
            Parameter param = new Parameter();
            param.setName(pp.getName());
            param.setType(ODataTypeManager.odataType(pp.getRuntimeType()).getFullQualifiedName());
            if (DataTypeManager.isArrayType(pp.getRuntimeType())) {
                param.setCollection(true);
            }
            param.setNullable(pp.getNullType() == .);
            params.add(param);
        }
        edmAction.setParameters(params);
        // add a complex type for return resultset.
        ColumnSet<ProcedurereturnColumns = proc.getResultSet();
        if (returnColumns != null) {
            ComplexType complexType = new ComplexType();
            String entityTypeName = proc.getName() + "_" + returnColumns.getName(); //$NON-NLS-1$
            complexType.setName(entityTypeName);
            ArrayList<Property> props = new ArrayList<Property>();
            for (Column c : returnColumns.getColumns()) {
                props.add(buildProperty(c));
            }
            complexType.setProperties(props);
            complexTypes.add(complexType);
            edmAction.setReturnType((new ReturnType().setType(new FullQualifiedName(schemaNamecomplexType.getName())).setCollection(true)));
        }
        ActionImport actionImport = new ActionImport();
        actionImport.setName(proc.getName()).setAction(new FullQualifiedName(schemaNameproc.getName()));
        actions.add(edmAction);
        actionImports.add(actionImport);
    }
    static List<StringgetColumnNames(List<Columncolumns) {
        ArrayList<Stringnames = new ArrayList<String>();
        for (Column c : columns) {
            names.add(c.getName());
        }
        return names;
    }
    static boolean sameColumnSet(KeyRecord recordOneKeyRecord recordTwo) {
        if (recordOne == null || recordTwo == null) {
            return false;
        }
        List<ColumnsetOne = recordOne.getColumns();
        List<ColumnsetTwo = recordTwo.getColumns();
        if (setOne.size() != setTwo.size()) {
            return false;
        }
        for (int i = 0; i < setOne.size(); i++) {
            Column one = setOne.get(i);
            Column two = setTwo.get(i);
            if (!one.getName().equals(two.getName())) {
                return false;
            }
        }
        return true;
    }
New to GrepCode? Check out our FAQ X