/*
* Copyright (C) 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.
* 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.jboss.errai.cdi.producer.server;
import javax.inject.Inject;
import org.jboss.errai.bus.client.api.base.MessageBuilder;
import org.jboss.errai.bus.client.api.messaging.Message;
import org.jboss.errai.bus.client.api.messaging.MessageBus;
import org.jboss.errai.bus.client.api.messaging.MessageCallback;
import org.jboss.errai.bus.server.annotations.Service;
import org.jboss.errai.cdi.producer.client.shared.LoggerTestUtil;
import org.jboss.errai.cdi.producer.client.shared.LoggerTestUtil.TestCommand;
import org.jboss.errai.common.client.api.annotations.NamedLogger;
import org.jboss.errai.common.client.protocols.MessageParts;
import org.slf4j.Logger;
@Service
public class ClassWithNamedLoggerField implements MessageCallback {
@Inject
@NamedLogger(LoggerTestUtil.LOGGER_NAME)
private Logger logger;
@Inject
private MessageBus bus;
@Override
public void callback(final Message message) {
final TestCommand command = TestCommand.valueOf(message.get(String.class, MessageParts.CommandType));
final Boolean res;
if (command.equals(TestCommand.IS_NOT_NULL)) {
res = logger != null;
MessageBuilder.createConversation(message).subjectProvided().with(LoggerTestUtil.RESULT_PART, res).done()
.sendNowWith(bus);
}
else if (command.equals(TestCommand.IS_CORRECT_NAME)) {
res = logger.getName().equals(LoggerTestUtil.LOGGER_NAME);
MessageBuilder.createConversation(message).subjectProvided().with(LoggerTestUtil.RESULT_PART, res).done()
.sendNowWith(bus);
}
}
}