All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.aequologica.neo.shakuntala.EventSpyImpl Maven / Gradle / Ivy

package net.aequologica.neo.shakuntala;

import static net.aequologica.neo.shakuntala.EventWriterDagImpl.DAG;
import static org.apache.maven.execution.ExecutionEvent.Type.SessionEnded;
import static org.apache.maven.execution.ExecutionEvent.Type.SessionStarted;

import java.net.InetAddress;
import java.net.UnknownHostException;
import java.nio.file.Paths;
import java.util.Date;
import java.util.HashSet;
import java.util.List;
import java.util.Properties;
import java.util.Set;

import javax.inject.Named;
import javax.inject.Singleton;

import org.apache.maven.eventspy.EventSpy;
import org.apache.maven.execution.ExecutionEvent;
import org.apache.maven.execution.MavenExecutionRequest;
import org.apache.maven.execution.MavenExecutionResult;
import org.apache.maven.execution.MavenSession;
import org.apache.maven.model.Developer;
import org.apache.maven.plugin.MojoExecution;
import org.apache.maven.project.MavenProject;
import org.apache.maven.settings.building.SettingsBuildingRequest;
import org.eclipse.aether.RepositoryEvent;

import net.aequologica.neo.shakuntala.dagr.DagComputer;

@Named
@Singleton
public class EventSpyImpl extends AbstractEventSpyImpl implements EventSpy {
    
    private Set throwables = new HashSet();
    
    @Override
    public void onEvent(final Object object) throws Exception {
        super.onEvent(gulp(object));
    }

    private Object gulp(final Object object) throws UnknownHostException, Exception {
        if (object == null) {
            return null;
        }

        if (object instanceof SettingsBuildingRequest) {
            InetAddress address = InetAddress.getLocalHost();

            if (address != null) {
                dispatch("hostName",    address.getHostName(),    Event.Level.info, object);
                dispatch("hostAddress", address.getHostAddress(), Event.Level.info, object);
            }
        // ----------------------------------------------------------------------------------------
        // maven execution request/result
        } else if (object instanceof MavenExecutionRequest) {
            MavenExecutionRequest executionRequest = (MavenExecutionRequest) object;
            String[] propertyKeys = new String[] {
                    "BUILD_URL",
                    "TRAVIS_BRANCH",
                    "TRAVIS_BUILD_ID",
                    "TRAVIS_COMMIT",
                    "TRAVIS_JOB_ID",
                    "TRAVIS_REPO_SLUG"
            };
            dispatchProperties(executionRequest, propertyKeys);
            
        } else if (object instanceof MavenExecutionResult) {
            MavenExecutionResult mavenExecutionResult = (MavenExecutionResult) object;
            List exceptions = mavenExecutionResult.getExceptions();
            if (exceptions != null) {
                for (Throwable throwable : exceptions) {
                    if (!throwables.contains(throwable)) {
                        dispatch("error", throwable.getMessage(), Event.Level.danger, object);
                        throwables.add(throwable);
                    }
                }
            }
        } else if (object instanceof ExecutionEvent) {
            ExecutionEvent executionEvent = (ExecutionEvent)object;

            MavenProject project = executionEvent.getProject();
            MojoExecution mojoExecution = executionEvent.getMojoExecution();

            Exception exception = executionEvent.getException();
            if (exception != null && !throwables.contains(exception)) {
                dispatch("error", exception.getMessage(), Event.Level.danger, object);
                throwables.add(exception);
            }

            ExecutionEvent.Type type = executionEvent.getType();

            if (type != null) {
                if (type.equals(SessionStarted)) {
                    MavenSession session = executionEvent.getSession();
                    if (session != null) {

                        MavenExecutionRequest request = session.getRequest();
                        MavenProject topLevelProject = session.getTopLevelProject();
                        
                        if (request != null) {
                            List goals = request.getGoals();
                            String goalsAsString = goals.toString();
                            dispatch("goals", goalsAsString, Event.Level.info, object);
                            String baseDirectory = request.getBaseDirectory();
                            dispatch("basedir", baseDirectory, Event.Level.info, object);
                            
                            if (config.isActive(DAG)) {
                                DagComputer dagComputer = new DagComputer(
                                        config.getDagName(), 
                                        Paths.get(baseDirectory), 
                                        session, 
                                        config.getDagDepth(), 
                                        config.getContextPath(), 
                                        config.getGitRemoteName()).compute();
                                
                                dispatch("dag", "dag", Event.Level.info, dagComputer);
                            }
                            
                        }

                        if (topLevelProject != null) {

                            // GAV
                            String groupId    = topLevelProject.getGroupId();
                            String artifactId = topLevelProject.getArtifactId();
                            String version    = topLevelProject.getVersion();
                            String packaging  = topLevelProject.getPackaging();

                            dispatch("groupId",    groupId,    Event.Level.info, object);
                            dispatch("artifactId", artifactId, Event.Level.info, object);
                            dispatch("version",    version,    Event.Level.info, object);
                            dispatch("packaging",  packaging,  Event.Level.info, object);

                            // lead dev
                            List developers = topLevelProject.getDevelopers();
                            if (developers.size() > 0) {
                                Developer developer = developers.get(0);
                                String email = developer.getEmail();
                                dispatch("email", email, Event.Level.info, object);
                            }
                        }
                    }
                } else if (type.equals(SessionEnded)) {
                    MavenSession session = executionEvent.getSession();
                    if (session != null) {
                        MavenExecutionResult result = session.getResult();
                        if (result != null) {
                            if (result.hasExceptions()) {
                                dispatch("result", Boolean.FALSE.toString(), Event.Level.danger, object);
                            } else {
                                dispatch("result", Boolean.TRUE.toString(),  Event.Level.success, object);
                            }
                        }

                        MavenExecutionRequest request = session.getRequest();
                        if (request != null) {
                            Date startTime = request.getStartTime();
                            if (startTime != null) {
                                Date finish = new Date();
                                long duration = finish.getTime() - startTime.getTime();
                                dispatch("duration", Long.toString(duration, 10), Event.Level.info, object);
                            }
                        }
                    }
                }
                
                if (project != null ) {
                    String value = type.toString();
                    if (mojoExecution != null) {
                        value = value + " (" + mojoExecution.toString() + ")";
                    }
                    dispatch(project.getName(), value, null, object);
                    return null;
                }
            }
        } else if (object instanceof RepositoryEvent) {
            RepositoryEvent repositoryEvent = (RepositoryEvent)object;
            if (repositoryEvent.getArtifact() != null) {
                EventAugmentedWithGloballyUniqueBuildResultIdentifier event = new EventAugmentedWithGloballyUniqueBuildResultIdentifier(object.getClass().getSimpleName(), object.toString(), null, object, repositoryEvent.getArtifact().toString());
                dispatch(event);
                return null;
            }
        }
        return object;
    }

    private void dispatchProperties(MavenExecutionRequest executionRequest, String[] propertyKeys) throws Exception {
        Properties userProperties = executionRequest.getUserProperties();
        Properties systemProperties = executionRequest.getSystemProperties();
        for (String propertyKey : propertyKeys) {
            if (userProperties != null) {
                String property = userProperties.getProperty(propertyKey);
                if (property != null && property.length() > 0) {
                    dispatch(propertyKey, property, Event.Level.info, executionRequest);
                } else {
                    if (systemProperties != null) {
                        property = systemProperties.getProperty("env."+propertyKey);
                        if (property != null && property.length() > 0) {
                            dispatch(propertyKey, property, Event.Level.info, executionRequest);
                        }
                    }
                }
            }
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy