/*
* Copyright 2015 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.
*
* 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.project.backend.social;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import javax.enterprise.context.ApplicationScoped;
import javax.inject.Inject;
import javax.inject.Named;
import org.guvnor.common.services.project.events.NewProjectEvent;
import org.guvnor.common.services.project.social.ProjectEventType;
import org.guvnor.structure.repositories.Repository;
import org.guvnor.structure.repositories.RepositoryService;
import org.ext.uberfire.social.activities.model.SocialActivitiesEvent;
import org.ext.uberfire.social.activities.model.SocialEventType;
import org.ext.uberfire.social.activities.repository.SocialUserRepository;
import org.ext.uberfire.social.activities.service.SocialAdapter;
import org.ext.uberfire.social.activities.service.SocialCommandTypeFilter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.uberfire.backend.server.util.Paths;
import org.uberfire.backend.vfs.Path;
@ApplicationScoped
public class NewProjectEventAdapter implements SocialAdapter<NewProjectEvent> {
private static final Logger logger = LoggerFactory.getLogger( NewProjectEventAdapter.class );
@Inject
private SocialUserRepository socialUserRepository;
@Inject
private RepositoryService repositoryService;
@Override
public Class<NewProjectEvent> eventToIntercept() {
return NewProjectEvent.class;
}
@Override
public SocialEventType socialEventType() {
return ProjectEventType.NEW_PROJECT;
}
@Override
public boolean shouldInterceptThisEvent( Object event ) {
return event.getClass().getSimpleName().equals( eventToIntercept().getSimpleName() );
}
@Override
public SocialActivitiesEvent toSocial( Object object ) {
SocialActivitiesEvent socialActivitiesEvent;
NewProjectEvent event = ( NewProjectEvent ) object;
Path repositoryRootPath = event.getProject().getRootPath();
Repository repository = null;
String repositoryAlias = null;
try {
repositoryRootPath = Paths.convert( Paths.convert( repositoryRootPath ).getRoot() );
repository = repositoryService.getRepository( repositoryRootPath );
repositoryAlias = repository.getAlias();
} catch ( Exception e ) {
logger.error( "It was not possible to establish the repository for project root path: " + event.getProject().getRootPath(), e );
logger.error( "Social event won't be fired for this project." );
}
socialActivitiesEvent = new SocialActivitiesEvent(
socialUserRepository.findSocialUser( event.getIdentity() ),
socialEventType().name(),
new Date()
)
.withDescription( event.getProject().getProjectName() );
if ( repositoryAlias != null ) {
socialActivitiesEvent.withLink( event.getProject().getProjectName(), event.getProject().getRootPath().toURI(), SocialActivitiesEvent.LINK_TYPE.CUSTOM )
.withParam( "repositoryAlias", repository.getAlias() )
.withParam( "currentBranch", "get the branch form the link");
}
socialActivitiesEvent.withAdicionalInfo( getAdditionalInfo( event ) );
return socialActivitiesEvent;
}
@Override
public List<SocialCommandTypeFilter> getTimelineFilters() {
return new ArrayList<SocialCommandTypeFilter>();
}
@Override
public List<String> getTimelineFiltersNames() {
return new ArrayList<String>();
}
private String getAdditionalInfo( NewProjectEvent event ) {
return "added";
}
}