br.gov.frameworkdemoiselle.component.audit.processors.rest.MONGOProcessors.java Source code

Java tutorial

Introduction

Here is the source code for br.gov.frameworkdemoiselle.component.audit.processors.rest.MONGOProcessors.java

Source

/*
 * Demoiselle Framework
 * Copyright (C) 2014 SERPRO
 * ----------------------------------------------------------------------------
 * This file is part of Demoiselle Framework.
 *
 * Demoiselle Framework is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public License version 3
 * as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License version 3
 * along with this program; if not,  see <http://www.gnu.org/licenses/>
 * or write to the Free Software Foundation, Inc., 51 Franklin Street,
 * Fifth Floor, Boston, MA  02110-1301, USA.
 * ----------------------------------------------------------------------------
 * Este arquivo  parte do Framework Demoiselle.
 *
 * O Framework Demoiselle  um software livre; voc pode redistribu-lo e/ou
 * modific-lo dentro dos termos da GNU LGPL verso 3 como publicada pela Fundao
 * do Software Livre (FSF).
 *
 * Este programa  distribudo na esperana que possa ser til, mas SEM NENHUMA
 * GARANTIA; sem uma garantia implcita de ADEQUAO a qualquer MERCADO ou
 * APLICAO EM PARTICULAR. Veja a Licena Pblica Geral GNU/LGPL em portugus
 * para maiores detalhes.
 *
 * Voc deve ter recebido uma cpia da GNU LGPL verso 3, sob o ttulo
 * "LICENCA.txt", junto com esse programa. Se no, acesse <http://www.gnu.org/licenses/>
 * ou escreva para a Fundao do Software Livre (FSF) Inc.,
 * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA.
 */
package br.gov.frameworkdemoiselle.component.audit.processors.rest;

import javax.enterprise.event.Observes;

import br.gov.frameworkdemoiselle.component.audit.domain.Trail;
import br.gov.frameworkdemoiselle.component.audit.implementation.processor.AbstractProcessor;
import br.gov.frameworkdemoiselle.component.audit.implementation.qualifier.AuditProcessor;
import br.gov.frameworkdemoiselle.util.Beans;

import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.MongoClient;

/**
 *
 * @author SERPRO
 *
 */
public class MONGOProcessors extends AbstractProcessor {

    private final MONGOConfig config = Beans.getReference(MONGOConfig.class);

    /**
     *
     * @param trail
     */
    @Override
    public void execute(@Observes @AuditProcessor Trail trail) {

        super.execute(trail);

        try {
            //TODO Verificar alternativas para superar a depreciao das classes abaixo
            MongoClient mongo = new MongoClient(config.getServerUrl());
            DB db = mongo.getDB(config.getDataBaseName());
            DBCollection table = db.getCollection(config.getTableName());

            BasicDBObject document = new BasicDBObject();
            document.put("ClassName", trail.getClassName());
            document.put("How", trail.getHow());
            document.put("IdName", trail.getIdName());
            document.put("LayerName", trail.getLayerName());
            document.put("ObjSerial", trail.getObjSerial());
            document.put("ProcessorName", trail.getProcessorName());
            document.put("Profile", trail.getProfile());
            document.put("SystemName", trail.getSystemName());
            document.put("UserName", trail.getUserName());
            document.put("What", trail.getWhat());
            document.put("When", trail.getWhen());
            document.put("Where", trail.getWhere());
            table.insert(document);

        } catch (Exception e) {
            fail("MONGOProcessors :" + e.getMessage(), trail);
        }
    }
}