]> git.mxchange.org Git - jcore-logger-ejb.git/blobdiff - src/java/org/mxchange/jcoreeelogger/beans/local/logger/LoggerFactory.java
Log and LoggerFactory must still reside in same package ... Well, the beans.xml did...
[jcore-logger-ejb.git] / src / java / org / mxchange / jcoreeelogger / beans / local / logger / LoggerFactory.java
diff --git a/src/java/org/mxchange/jcoreeelogger/beans/local/logger/LoggerFactory.java b/src/java/org/mxchange/jcoreeelogger/beans/local/logger/LoggerFactory.java
new file mode 100644 (file)
index 0000000..0fec8f1
--- /dev/null
@@ -0,0 +1,48 @@
+/*
+ * Copyright (C) 2015 Roland Haeder
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * 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 General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+package org.mxchange.jcoreeelogger.beans.local.logger;
+
+import javax.enterprise.inject.Produces;
+import javax.enterprise.inject.spi.InjectionPoint;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
+
+/**
+ * A logger factory
+ *
+ * @author Roland Haeder
+ */
+public class LoggerFactory {
+
+       /**
+        * Own logger
+        */
+       private final Logger logger;
+
+       /**
+        * Factory method
+        */
+       public LoggerFactory () {
+               this.logger = LogManager.getLogger(this.getClass().getName());
+       }
+
+       @Produces
+       @Log
+       public Logger getLogger (final InjectionPoint caller) {
+               return LogManager.getLogger(caller.getMember().getDeclaringClass().getName());
+       }
+}