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

com.crashnote.core.collect.Collector Maven / Gradle / Ivy

/**
 * Copyright (C) 2011 - 101loops.com 
 *
 * 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 com.crashnote.core.collect;

import com.crashnote.core.Lifecycle;
import com.crashnote.core.collect.impl.*;
import com.crashnote.core.config.Config;
import com.crashnote.core.model.data.DataObject;
import com.crashnote.core.model.log.*;

import java.util.*;

/**
 * This class provides the functionality to transform events, state, properties and context data
 * into a structured form that can be parsed by an external API. The structure is based on
 * abstract object and array containers.
 */
public class Collector
    extends BaseCollector implements Lifecycle {

    private boolean started;
    private final EnvCollector env_c;
    private final LogCollector log_c;

    // SETUP ======================================================================================

    public Collector(final C config) {
        super(config);

        this.env_c = createEnvColl(config);
        this.log_c = createLogColl(config);
    }

    // LIFECYCLE ==================================================================================

    public boolean start() {
        if (!started) {
            started = true;
            getLogger().debug("starting module [collector]");
        }
        return started;
    }

    public boolean stop() {
        if (started) {
            started = false;
            getLogger().debug("stopping module [collector]");
        }
        return started;
    }

    // INTERFACE ==================================================================================

    public DataObject collectLog(final ILogSession session) {
        final DataObject data = createDataObj();
        {
            final List> logs = session.getEvents();

            // log(s)
            if (logs.size() == 1)
                data.putObj("log", log_c.collect(logs.get(0)));
            else
                data.putArr("log", log_c.collect(logs));

            // ctx
            final DataObject ctx = createDataObj();
            {
                final Map map = session.getContext();
                for (final String key : map.keySet()) {
                    final Object val = map.get(key);
                    ctx.put(key, val);
                }
            }
            data.putObj("ctx", ctx);

            // env
            data.putObj("env", env_c.collect());
        }
        return data;
    }

    // FACTORY ====================================================================================

    protected EnvCollector createEnvColl(final C config) {
        return new EnvCollector(config);
    }

    protected LogCollector createLogColl(final C config) {
        return new LogCollector(config);
    }

    // GET ========================================================================================

    public EnvCollector getEnvCollector() {
        return env_c;
    }

    public LogCollector getLogCollector() {
        return log_c;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy