/*
* JBoss, Home of Professional Open Source
* Copyright 2013, Red Hat Middleware LLC, and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* 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.arquillian.extension.recorder.video.desktop.configuration;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.arquillian.extension.recorder.video.VideoConfiguration;
import org.arquillian.extension.recorder.video.VideoConfigurator;
import org.arquillian.extension.recorder.video.event.VideoExtensionConfigured;
import org.arquillian.recorder.reporter.ReporterConfiguration;
import org.arquillian.recorder.reporter.event.ReportingExtensionConfigured;
import org.jboss.arquillian.config.descriptor.api.ArquillianDescriptor;
import org.jboss.arquillian.config.descriptor.api.ExtensionDef;
import org.jboss.arquillian.core.api.Event;
import org.jboss.arquillian.core.api.Instance;
import org.jboss.arquillian.core.api.InstanceProducer;
import org.jboss.arquillian.core.api.annotation.ApplicationScoped;
import org.jboss.arquillian.core.api.annotation.Inject;
import org.jboss.arquillian.core.api.annotation.Observes;
/**
* Observes:
* <ul>
* <li>{@link ReportingExtensionConfigured}</li>
* </ul>
* Produces {@link ApplicationScoped}:
* <ul>
* <li>{@link VideoConfiguration}</li>
* </ul>
* Fires:
* <ul>
* <li>{@link VideoExtensionConfigured}</li>
* </ul>
* @author <a href="mailto:pmensik@redhat.com">Petr Mensik</a>
* @author <a href="mailto:smikloso@redhat.com">Stefan Miklosovic</a>
*/
public class DesktopVideoRecorderConfigurator extends VideoConfigurator {
private static final Logger logger = Logger.getLogger(DesktopVideoRecorderConfigurator.class.getSimpleName());
@Inject
@ApplicationScoped
private InstanceProducer<VideoConfiguration> configuration;
@Inject
private Instance<ReporterConfiguration> reporterConfiguration;
@Inject
private Event<VideoExtensionConfigured> extensionConfiguredEvent;
public void configureExtension(@Observes ReportingExtensionConfigured event, ArquillianDescriptor descriptor) {
VideoConfiguration configuration = new DesktopVideoConfiguration(reporterConfiguration.get());
for (ExtensionDef extension : descriptor.getExtensions()) {
if (extension.getExtensionName().equals(EXTENSION_NAME)) {
configuration.setConfiguration(extension.getExtensionProperties());
configuration.validate();
break;
}
}
this.configuration.set(configuration);
if (logger.isLoggable(Level.INFO)) {
System.out.println("Configuration of Arquillian Desktop Video Recorder:");
System.out.println(this.configuration.get().toString());
}
extensionConfiguredEvent.fire(new VideoExtensionConfigured());
}
}