/*
* Copyright 2012 Red Hat, Inc. and/or its affiliates.
*
* 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.guvnor.common.services.workingset.client;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import javax.enterprise.context.ApplicationScoped;
import javax.enterprise.event.Observes;
import javax.inject.Inject;
import org.guvnor.common.services.project.model.Project;
import org.guvnor.common.services.project.service.ProjectService;
import org.guvnor.common.services.workingset.client.events.OnWorkingSetApplied;
import org.guvnor.common.services.workingset.client.events.OnWorkingSetDisabled;
import org.guvnor.common.services.workingset.client.factconstraints.ConstraintConfiguration;
import org.guvnor.common.services.workingset.client.factconstraints.customform.CustomFormConfiguration;
import org.guvnor.common.services.workingset.client.factconstraints.helper.CustomFormsContainer;
import org.guvnor.common.services.workingset.client.model.WorkingSetConfigData;
import org.guvnor.common.services.workingset.client.model.WorkingSetSettings;
import org.jboss.errai.common.client.api.Caller;
import org.uberfire.backend.vfs.Path;
//import org.uberfire.commons.data.Pair;
@ApplicationScoped
public class WorkingSetManager {
private Map<Path, WorkingSetSettings> projectSettings = new HashMap<Path, WorkingSetSettings>();
@Inject
private Caller<ProjectService<? super Project>> projectService;
/**
* This attribute should be sever side. Maybe in some FactConstraintConfig
* object.
*/
private boolean autoVerifierEnabled = false;
public void onWorkingSetApplied( @Observes final OnWorkingSetApplied event ) {
// final Pair<Path, WorkingSetSettings> projectReference = getProjectConfig( event.getResource() );
// if ( projectReference != null && projectReference.getK2() == null ) {
// projectService.call( new RemoteCallback<WorkingSetSettings>() {
// @Override
// public void callback( final WorkingSetSettings response ) {
// projectSettings.put( projectReference.getK1(), response );
// }
// } ).loadWorkingSetConfig( projectReference.getK1() );
// }
}
public void onWorkingSetDisabled( @Observes final OnWorkingSetDisabled event ) {
final WorkingSetSettings settings = getActiveSettings( event.getResource() );
if ( settings != null ) {
settings.removeWorkingSet( event.getWorkingSet() );
}
}
/**
* Returns the active WorkingSets for a package, or null if any.
* @param resource the resource - part of a project
* @return the active WorkingSets for a package, or null if any.
*/
public Collection<WorkingSetConfigData> getActiveWorkingSets( final Path resource ) {
final WorkingSetSettings result = getActiveSettings( resource );
if ( result == null ) {
return null;
}
return result.getConfigData();
}
// public Pair<Path, WorkingSetSettings> getProjectConfig( final Path resource ) {
// final Path project = projectResources.getProject( resource );
// if ( project == null ) {
// return null;
// }
// return new Pair<Path, WorkingSetSettings>( project, projectSettings.get( project ) );
// }
public WorkingSetSettings getActiveSettings( final Path resource ) {
// final Path projectReference = projectResources.getProject( resource );
// if ( projectReference == null ) {
// return null;
// }
// return projectSettings.get( projectReference );
return null;
}
public void removeWorkingSets( final Path resource ) {
// final Path projectReference = projectResources.getProject( resource );
// if ( projectReference != null ) {
// projectSettings.remove( projectReference );
// }
}
/**
* Returns whether the given (WorkingSet) RuleSet is active in a project or not.
* @param resource the resource.
* @param workingSet the (WorkingSet) RuleSet
* @return whether the given (WorkingSet) RuleSet is active in a project or not.
*/
public boolean isWorkingSetActive( final Path resource,
final Path workingSet ) {
final WorkingSetSettings result = getActiveSettings( resource );
if ( result == null ) {
return false;
}
return result.getResources().contains( workingSet );
}
/**
* Returns a Set of Constraints for a Fact Type's field. This method uses
* the active Working Sets of the project in order to get the Constraints.
* @param resource the resource.
* @param factType the Fact Type (Short class name)
* @param fieldName the field name
* @return a Set of Constraints for a Fact Type's field.
*/
public Set<ConstraintConfiguration> getFieldContraints( final Path resource,
final String factType,
final String fieldName ) {
final Set<ConstraintConfiguration> result = new HashSet<ConstraintConfiguration>();
//TODO: Change this with a centralized way of Constraint Administration.
final Collection<WorkingSetConfigData> activeConfig = this.getActiveWorkingSets( resource );
if ( activeConfig != null ) {
for ( final WorkingSetConfigData configData : activeConfig ) {
final List<ConstraintConfiguration> constraints = configData.getConstraints();
if ( constraints != null ) {
for ( final ConstraintConfiguration constraint : constraints ) {
if ( constraint.getFactType().equals( factType ) && constraint.getFieldName().equals( fieldName ) ) {
result.add( constraint );
}
}
}
}
}
return result;
}
/**
* TODO: We need to store/retrieve this value from repository
* @return
*/
public boolean isAutoVerifierEnabled() {
return autoVerifierEnabled;
}
/**
* TODO: We need to store/retrieve this value from repository
*/
public void setAutoVerifierEnabled( boolean autoVerifierEnabled ) {
this.autoVerifierEnabled = autoVerifierEnabled;
}
/**
* Returns the associated CustomFormConfiguration for a given FactType and FieldName.
* Because CustomFormConfiguration is stored inside a WorkingSet, the
* packageName attribute is used to retrieve all the active WorkingSets.
* If more than one active WorkingSet contain a CustomFormConfiguration for
* the given FactType and FieldName the first to be found (in any specific
* nor deterministic order) will be returned.
* @param resource the resource (part of of a project). Used to get the active
* working sets of the active resource project
* @param factType The short class name of the Fact Type
* @param fieldName The field name
* @return the associated CustomFormConfiguration for the given FactType and
* FieldName in the active working sets or null if any.
*/
public CustomFormConfiguration getCustomFormConfiguration( final Path resource,
final String factType,
final String fieldName ) {
final Collection<WorkingSetConfigData> packageWorkingSets = this.getActiveWorkingSets( resource );
if ( packageWorkingSets != null ) {
final List<CustomFormConfiguration> configs = new ArrayList<CustomFormConfiguration>();
for ( final WorkingSetConfigData workingSetConfigData : packageWorkingSets ) {
if ( workingSetConfigData.getCustomForms() != null && !workingSetConfigData.getCustomForms().isEmpty() ) {
configs.addAll( workingSetConfigData.getCustomForms() );
}
}
final CustomFormsContainer cfc = new CustomFormsContainer( configs );
if ( cfc.containsCustomFormFor( factType, fieldName ) ) {
return cfc.getCustomForm( factType, fieldName );
}
}
return null;
}
}