Search in sources :

Example 1 with LogicalFlowDecorator

use of org.finos.waltz.schema.tables.LogicalFlowDecorator in project waltz by khartec.

the class LogicalFlowDecoratorDao method updateDecoratorsForFlowClassificationRule.

public int updateDecoratorsForFlowClassificationRule(FlowClassificationRuleVantagePoint flowClassificationRuleVantagePoint) {
    LogicalFlowDecorator lfd = LOGICAL_FLOW_DECORATOR.as("lfd");
    EntityReference vantagePoint = flowClassificationRuleVantagePoint.vantagePoint();
    Long appId = flowClassificationRuleVantagePoint.applicationId();
    EntityReference dataType = flowClassificationRuleVantagePoint.dataType();
    String classificationCode = flowClassificationRuleVantagePoint.classificationCode();
    SelectConditionStep<Record1<Long>> orgUnitSubselect = DSL.select(ENTITY_HIERARCHY.ID).from(ENTITY_HIERARCHY).where(ENTITY_HIERARCHY.KIND.eq(vantagePoint.kind().name())).and(ENTITY_HIERARCHY.ANCESTOR_ID.eq(vantagePoint.id()));
    SelectConditionStep<Record1<Long>> dataTypeSubselect = DSL.select(ENTITY_HIERARCHY.ID).from(ENTITY_HIERARCHY).where(ENTITY_HIERARCHY.KIND.eq(DATA_TYPE.name())).and(ENTITY_HIERARCHY.ANCESTOR_ID.eq(dataType.id()));
    Condition usingFlowClassificationRule = LOGICAL_FLOW.SOURCE_ENTITY_ID.eq(appId);
    Condition notUsingFlowClassificationRule = LOGICAL_FLOW.SOURCE_ENTITY_ID.ne(appId);
    Function2<Condition, String, Update<LogicalFlowDecoratorRecord>> mkQuery = (appScopingCondition, ratingName) -> dsl.update(LOGICAL_FLOW_DECORATOR).set(LOGICAL_FLOW_DECORATOR.RATING, ratingName).set(LOGICAL_FLOW_DECORATOR.FLOW_CLASSIFICATION_RULE_ID, flowClassificationRuleVantagePoint.ruleId()).where(LOGICAL_FLOW_DECORATOR.ID.in(DSL.select(lfd.ID).from(lfd).innerJoin(LOGICAL_FLOW).on(LOGICAL_FLOW.ID.eq(lfd.LOGICAL_FLOW_ID)).innerJoin(APPLICATION).on(APPLICATION.ID.eq(LOGICAL_FLOW.TARGET_ENTITY_ID).and(LOGICAL_FLOW.TARGET_ENTITY_KIND.eq(EntityKind.APPLICATION.name()))).where(LOGICAL_FLOW.SOURCE_ENTITY_KIND.eq(EntityKind.APPLICATION.name()).and(appScopingCondition).and(APPLICATION.ORGANISATIONAL_UNIT_ID.in(orgUnitSubselect)).and(lfd.DECORATOR_ENTITY_KIND.eq(DATA_TYPE.name())).and(lfd.DECORATOR_ENTITY_ID.in(dataTypeSubselect))).and(lfd.RATING.in(AuthoritativenessRatingValue.NO_OPINION.value(), AuthoritativenessRatingValue.DISCOURAGED.value()))));
    Update<LogicalFlowDecoratorRecord> updateAuthSources = mkQuery.apply(usingFlowClassificationRule, classificationCode);
    Update<LogicalFlowDecoratorRecord> updateNonAuthSources = mkQuery.apply(notUsingFlowClassificationRule, AuthoritativenessRatingValue.DISCOURAGED.value());
    int authSourceUpdateCount = updateAuthSources.execute();
    int nonAuthSourceUpdateCount = updateNonAuthSources.execute();
    return authSourceUpdateCount + nonAuthSourceUpdateCount;
}
Also used : AuthoritativenessRatingValue(org.finos.waltz.model.rating.AuthoritativenessRatingValue) DSL(org.jooq.impl.DSL) APPLICATION(org.finos.waltz.schema.tables.Application.APPLICATION) LogicalFlowDecoratorRecord(org.finos.waltz.schema.tables.records.LogicalFlowDecoratorRecord) EntityKind(org.finos.waltz.model.EntityKind) LOGICAL_DATA_FLOW(org.finos.waltz.model.EntityKind.LOGICAL_DATA_FLOW) Autowired(org.springframework.beans.factory.annotation.Autowired) ListUtilities.newArrayList(org.finos.waltz.common.ListUtilities.newArrayList) Function(java.util.function.Function) EntityReference.mkRef(org.finos.waltz.model.EntityReference.mkRef) LOGICAL_FLOW(org.finos.waltz.schema.tables.LogicalFlow.LOGICAL_FLOW) LOGICAL_NOT_REMOVED(org.finos.waltz.data.logical_flow.LogicalFlowDao.LOGICAL_NOT_REMOVED) FlowClassificationRuleVantagePoint(org.finos.waltz.model.flow_classification_rule.FlowClassificationRuleVantagePoint) Function2(org.jooq.lambda.function.Function2) org.jooq(org.jooq) PHYSICAL_FLOW(org.finos.waltz.schema.Tables.PHYSICAL_FLOW) LogicalFlowDecorator(org.finos.waltz.schema.tables.LogicalFlowDecorator) Repository(org.springframework.stereotype.Repository) ENTITY_HIERARCHY(org.finos.waltz.schema.tables.EntityHierarchy.ENTITY_HIERARCHY) EntityLifecycleStatus(org.finos.waltz.model.EntityLifecycleStatus) LOGICAL_FLOW_DECORATOR(org.finos.waltz.schema.tables.LogicalFlowDecorator.LOGICAL_FLOW_DECORATOR) DataTypeDecorator(org.finos.waltz.model.datatype.DataTypeDecorator) Timestamp(java.sql.Timestamp) Collection(java.util.Collection) DataTypeUsageCharacteristics(org.finos.waltz.model.datatype.DataTypeUsageCharacteristics) Set(java.util.Set) ImmutableDataTypeUsageCharacteristics(org.finos.waltz.model.datatype.ImmutableDataTypeUsageCharacteristics) ImmutableDataTypeDecorator(org.finos.waltz.model.datatype.ImmutableDataTypeDecorator) String.format(java.lang.String.format) PHYSICAL_SPEC_DATA_TYPE(org.finos.waltz.schema.tables.PhysicalSpecDataType.PHYSICAL_SPEC_DATA_TYPE) List(java.util.List) Collectors.toList(java.util.stream.Collectors.toList) Checks.checkNotNull(org.finos.waltz.common.Checks.checkNotNull) InlineSelectFieldFactory(org.finos.waltz.data.InlineSelectFieldFactory) SetUtilities(org.finos.waltz.common.SetUtilities) EntityReference(org.finos.waltz.model.EntityReference) Optional(java.util.Optional) DATA_TYPE(org.finos.waltz.model.EntityKind.DATA_TYPE) LogicalFlowDecoratorRecord(org.finos.waltz.schema.tables.records.LogicalFlowDecoratorRecord) LogicalFlowDecorator(org.finos.waltz.schema.tables.LogicalFlowDecorator) FlowClassificationRuleVantagePoint(org.finos.waltz.model.flow_classification_rule.FlowClassificationRuleVantagePoint) EntityReference(org.finos.waltz.model.EntityReference)

Aggregations

String.format (java.lang.String.format)1 Timestamp (java.sql.Timestamp)1 Collection (java.util.Collection)1 List (java.util.List)1 Optional (java.util.Optional)1 Set (java.util.Set)1 Function (java.util.function.Function)1 Collectors.toList (java.util.stream.Collectors.toList)1 Checks.checkNotNull (org.finos.waltz.common.Checks.checkNotNull)1 ListUtilities.newArrayList (org.finos.waltz.common.ListUtilities.newArrayList)1 SetUtilities (org.finos.waltz.common.SetUtilities)1 InlineSelectFieldFactory (org.finos.waltz.data.InlineSelectFieldFactory)1 LOGICAL_NOT_REMOVED (org.finos.waltz.data.logical_flow.LogicalFlowDao.LOGICAL_NOT_REMOVED)1 EntityKind (org.finos.waltz.model.EntityKind)1 DATA_TYPE (org.finos.waltz.model.EntityKind.DATA_TYPE)1 LOGICAL_DATA_FLOW (org.finos.waltz.model.EntityKind.LOGICAL_DATA_FLOW)1 EntityLifecycleStatus (org.finos.waltz.model.EntityLifecycleStatus)1 EntityReference (org.finos.waltz.model.EntityReference)1 EntityReference.mkRef (org.finos.waltz.model.EntityReference.mkRef)1 DataTypeDecorator (org.finos.waltz.model.datatype.DataTypeDecorator)1