Search in sources :

Example 1 with BusinessDAOQuery

use of com.runwaysdk.query.BusinessDAOQuery in project geoprism-registry by terraframe.

the class HierarchyExporter method getGeoEntityRelationships.

/**
 * Returns a list of {@link MdTermRelationshipDAOIF} that defines relationships between geoentities.
 *
 * @return list of {@link MdTermRelationshipDAOIF} that defines relationships between geoentities.
 */
private static List<MdTermRelationshipDAOIF> getGeoEntityRelationships() {
    List<MdTermRelationshipDAOIF> list = new LinkedList<MdTermRelationshipDAOIF>();
    QueryFactory qf = new QueryFactory();
    // Export the MdTermRelationships that involve universals
    MdBusiness geoEntityMdBusiness = MdBusiness.getMdBusiness(GeoEntity.CLASS);
    BusinessDAOQuery trQ = qf.businessDAOQuery(MdTermRelationship.CLASS);
    trQ.WHERE(trQ.get(MdTermRelationship.PARENTMDBUSINESS).EQ(geoEntityMdBusiness.getOid()).AND(trQ.get(MdTermRelationship.CHILDMDBUSINESS).EQ(geoEntityMdBusiness.getOid())));
    OIterator<? extends BusinessDAOIF> mdtrI = trQ.getIterator();
    try {
        while (mdtrI.hasNext()) {
            MdTermRelationshipDAOIF businessDAOIF = (MdTermRelationshipDAOIF) mdtrI.next();
            list.add(businessDAOIF);
        }
    } finally {
        mdtrI.close();
    }
    return list;
}
Also used : MdTermRelationshipDAOIF(com.runwaysdk.dataaccess.MdTermRelationshipDAOIF) QueryFactory(com.runwaysdk.query.QueryFactory) MdBusiness(com.runwaysdk.system.metadata.MdBusiness) BusinessDAOQuery(com.runwaysdk.query.BusinessDAOQuery) LinkedList(java.util.LinkedList)

Example 2 with BusinessDAOQuery

use of com.runwaysdk.query.BusinessDAOQuery in project geoprism-registry by terraframe.

the class HierarchyExporter method exportHierarchyDefinition.

/**
 * Exports the metadata for the hierarchies. If a
 * file of the specified filename already exists then the file is overwritten.
 *
 * @param fileName
 *            The name of the xml file to create.
 * @param schemaLocation
 *            The location of the schema
 * @param _exportOnlyModifiedAttributes
 *             True if only modified attributes should be exported, false otherwise.
 */
@Request
public static void exportHierarchyDefinition(String fileName, String schemaLocation, boolean _exportOnlyModifiedAttributes) {
    ExportMetadata exportMetadata = new ExportMetadata();
    QueryFactory qf = new QueryFactory();
    // Export the MdBusinesses that define the hierarchy attributes
    BusinessDAOQuery uQ = qf.businessDAOQuery(Universal.CLASS);
    BusinessDAOQuery mdbQ = qf.businessDAOQuery(MdBusiness.CLASS);
    mdbQ.WHERE(mdbQ.aUUID(MdBusiness.OID).EQ(uQ.aReference(Universal.MDBUSINESS).aUUID(Universal.OID)));
    OIterator<? extends BusinessDAOIF> mdbI = mdbQ.getIterator();
    try {
        while (mdbI.hasNext()) {
            MdBusinessDAOIF mdBusiness = (MdBusinessDAOIF) mdbI.next();
            System.out.println(mdBusiness.getType() + "  " + mdBusiness.getTypeName());
            exportMetadata.addCreateOrUpdate(mdBusiness);
        }
    } finally {
        mdbI.close();
    }
    // Export the Universals
    uQ = qf.businessDAOQuery(Universal.CLASS);
    OIterator<? extends BusinessDAOIF> uQI = uQ.getIterator();
    try {
        while (uQI.hasNext()) {
            BusinessDAOIF businessDAOIF = (BusinessDAOIF) uQI.next();
            System.out.println(businessDAOIF.getType() + "  " + businessDAOIF.getKey());
            exportMetadata.addCreateOrUpdate(businessDAOIF);
        }
    } finally {
        mdbI.close();
    }
    // Export the MdTermRelationships that involve universals
    List<MdTermRelationshipDAOIF> universalRelList = getUniversalRelationships();
    for (MdTermRelationshipDAOIF mdTermRelationshipDAOIF : universalRelList) {
        System.out.println(mdTermRelationshipDAOIF.getType() + "  " + mdTermRelationshipDAOIF.getKey());
        exportMetadata.addCreateOrUpdate(mdTermRelationshipDAOIF);
    }
    // Export the instances of the relationships between the universals.
    for (MdTermRelationshipDAOIF mdTermRelationshipDAOIF : universalRelList) {
        RelationshipDAOQuery relQ = qf.relationshipDAOQuery(mdTermRelationshipDAOIF.definesType());
        OIterator<RelationshipDAOIF> relI = relQ.getIterator();
        try {
            while (relI.hasNext()) {
                RelationshipDAOIF relationshipDAOIF = relI.next();
                exportMetadata.addCreateOrUpdate(relationshipDAOIF);
            }
        } finally {
            relI.close();
        }
    }
    List<MdTermRelationshipDAOIF> geoEntityRelList = getGeoEntityRelationships();
    for (MdTermRelationshipDAOIF mdTermRelationshipDAOIF : geoEntityRelList) {
        System.out.println(mdTermRelationshipDAOIF.getType() + "  " + mdTermRelationshipDAOIF.getKey());
        exportMetadata.addCreateOrUpdate(mdTermRelationshipDAOIF);
    }
    VersionExporter.export(fileName, schemaLocation, exportMetadata);
// FileInstanceExporter.export(fileName, schemaLocation, queries, _exportOnlyModifiedAttributes);
}
Also used : MdTermRelationshipDAOIF(com.runwaysdk.dataaccess.MdTermRelationshipDAOIF) ExportMetadata(com.runwaysdk.dataaccess.io.dataDefinition.ExportMetadata) QueryFactory(com.runwaysdk.query.QueryFactory) MdBusinessDAOIF(com.runwaysdk.dataaccess.MdBusinessDAOIF) MdTermRelationshipDAOIF(com.runwaysdk.dataaccess.MdTermRelationshipDAOIF) RelationshipDAOIF(com.runwaysdk.dataaccess.RelationshipDAOIF) RelationshipDAOQuery(com.runwaysdk.query.RelationshipDAOQuery) MdBusinessDAOIF(com.runwaysdk.dataaccess.MdBusinessDAOIF) BusinessDAOIF(com.runwaysdk.dataaccess.BusinessDAOIF) BusinessDAOQuery(com.runwaysdk.query.BusinessDAOQuery) Request(com.runwaysdk.session.Request)

Example 3 with BusinessDAOQuery

use of com.runwaysdk.query.BusinessDAOQuery in project geoprism-registry by terraframe.

the class ListTypeVersionRequiredDefaults method dotItInTrans.

@Transaction
private void dotItInTrans() {
    BusinessDAOQuery query = new QueryFactory().businessDAOQuery(ListTypeVersion.CLASS);
    query.WHERE(query.aBoolean(ListTypeVersion.WORKING).EQ(true));
    query.AND(query.aCharacter(ListTypeVersion.LISTVISIBILITY).EQ((String) null).OR(query.aCharacter(ListTypeVersion.GEOSPATIALVISIBILITY).EQ((String) null)));
    logger.info("About to patch " + query.getCount() + " ListTypeVersions with default values for visiblity.");
    OIterator<BusinessDAOIF> it = query.getIterator();
    try {
        while (it.hasNext()) {
            BusinessDAO version = (BusinessDAO) it.next();
            if (version.getValue(ListTypeVersion.LISTVISIBILITY) == null || version.getValue(ListTypeVersion.LISTVISIBILITY).length() == 0) {
                version.setValue(ListTypeVersion.LISTVISIBILITY, ListType.PRIVATE);
            }
            if (version.getValue(ListTypeVersion.GEOSPATIALVISIBILITY) == null || version.getValue(ListTypeVersion.GEOSPATIALVISIBILITY).length() == 0) {
                version.setValue(ListTypeVersion.GEOSPATIALVISIBILITY, ListType.PRIVATE);
            }
            version.apply();
        }
    } finally {
        it.close();
    }
}
Also used : QueryFactory(com.runwaysdk.query.QueryFactory) BusinessDAO(com.runwaysdk.dataaccess.BusinessDAO) BusinessDAOIF(com.runwaysdk.dataaccess.BusinessDAOIF) BusinessDAOQuery(com.runwaysdk.query.BusinessDAOQuery) Transaction(com.runwaysdk.dataaccess.transaction.Transaction)

Example 4 with BusinessDAOQuery

use of com.runwaysdk.query.BusinessDAOQuery in project geoprism-registry by terraframe.

the class HierarchyExporter method exportUniversalInstances.

/**
 * Export all instances of the given {@link Universal} type.
 *
 * @param universal
 */
private static void exportUniversalInstances(ExportMetadata exportMetadata, Universal universal) {
    boolean isLeafType = universal.getIsLeafType();
    MdBusiness mdBusiness = universal.getMdBusiness();
    QueryFactory qf = new QueryFactory();
    BusinessDAOQuery q = qf.businessDAOQuery(mdBusiness.definesType());
    System.out.println("\nExporting Universal [" + universal.getUniversalId() + "] instances:");
    System.out.println("-----------------------------------------------------------------------");
    int counter = 0;
    OIterator<BusinessDAOIF> i = q.getIterator();
    try {
        for (BusinessDAOIF businessDAOIF : i) {
            if (!isLeafType) {
                BusinessDAOIF geoEntity = ((AttributeReferenceIF) businessDAOIF.getAttributeIF(RegistryConstants.GEO_ENTITY_ATTRIBUTE_NAME)).dereference();
                exportMetadata.addCreate(geoEntity);
            }
            exportMetadata.addCreate(businessDAOIF);
            System.out.print(".");
            if (counter % 100 == 0) {
                System.out.println();
            }
            counter++;
        }
    } finally {
        i.close();
    }
}
Also used : QueryFactory(com.runwaysdk.query.QueryFactory) MdBusiness(com.runwaysdk.system.metadata.MdBusiness) MdBusinessDAOIF(com.runwaysdk.dataaccess.MdBusinessDAOIF) BusinessDAOIF(com.runwaysdk.dataaccess.BusinessDAOIF) BusinessDAOQuery(com.runwaysdk.query.BusinessDAOQuery) AttributeReferenceIF(com.runwaysdk.dataaccess.AttributeReferenceIF)

Example 5 with BusinessDAOQuery

use of com.runwaysdk.query.BusinessDAOQuery in project geoprism-registry by terraframe.

the class HierarchyExporter method getUniversalRelationships.

/**
 * Returns a list of {@link MdTermRelationshipDAOIF} that defines relationships between universals.
 *
 * @return list of {@link MdTermRelationshipDAOIF} that defines relationships between universals.
 */
private static List<MdTermRelationshipDAOIF> getUniversalRelationships() {
    List<MdTermRelationshipDAOIF> list = new LinkedList<MdTermRelationshipDAOIF>();
    QueryFactory qf = new QueryFactory();
    // Export the MdTermRelationships that involve universals
    MdBusiness univMdBusiness = MdBusiness.getMdBusiness(Universal.CLASS);
    BusinessDAOQuery trQ = qf.businessDAOQuery(MdTermRelationship.CLASS);
    trQ.WHERE(trQ.get(MdTermRelationship.PARENTMDBUSINESS).EQ(univMdBusiness.getOid()).AND(trQ.get(MdTermRelationship.CHILDMDBUSINESS).EQ(univMdBusiness.getOid())));
    OIterator<? extends BusinessDAOIF> mdtrI = trQ.getIterator();
    try {
        while (mdtrI.hasNext()) {
            MdTermRelationshipDAOIF businessDAOIF = (MdTermRelationshipDAOIF) mdtrI.next();
            list.add(businessDAOIF);
        }
    } finally {
        mdtrI.close();
    }
    return list;
}
Also used : MdTermRelationshipDAOIF(com.runwaysdk.dataaccess.MdTermRelationshipDAOIF) QueryFactory(com.runwaysdk.query.QueryFactory) MdBusiness(com.runwaysdk.system.metadata.MdBusiness) BusinessDAOQuery(com.runwaysdk.query.BusinessDAOQuery) LinkedList(java.util.LinkedList)

Aggregations

BusinessDAOQuery (com.runwaysdk.query.BusinessDAOQuery)5 QueryFactory (com.runwaysdk.query.QueryFactory)5 BusinessDAOIF (com.runwaysdk.dataaccess.BusinessDAOIF)3 MdTermRelationshipDAOIF (com.runwaysdk.dataaccess.MdTermRelationshipDAOIF)3 MdBusiness (com.runwaysdk.system.metadata.MdBusiness)3 MdBusinessDAOIF (com.runwaysdk.dataaccess.MdBusinessDAOIF)2 LinkedList (java.util.LinkedList)2 AttributeReferenceIF (com.runwaysdk.dataaccess.AttributeReferenceIF)1 BusinessDAO (com.runwaysdk.dataaccess.BusinessDAO)1 RelationshipDAOIF (com.runwaysdk.dataaccess.RelationshipDAOIF)1 ExportMetadata (com.runwaysdk.dataaccess.io.dataDefinition.ExportMetadata)1 Transaction (com.runwaysdk.dataaccess.transaction.Transaction)1 RelationshipDAOQuery (com.runwaysdk.query.RelationshipDAOQuery)1 Request (com.runwaysdk.session.Request)1