after a lot of work initialization at startup is now working.
[photos] / src / main / java / org / wamblee / photos / model / plumbing / Initializer.java
index 250964148edf1b745666fbd7cf83826108f0a64e..b5ace148c012cb1b953fdacc1d0f22f13cb0a8f9 100644 (file)
  */
 package org.wamblee.photos.model.plumbing;
 
+import java.util.logging.Logger;
+
 import javax.annotation.PostConstruct;
 import javax.ejb.Singleton;
 import javax.ejb.Startup;
 import javax.inject.Inject;
 
+import org.wamblee.inject.InjectorBuilder;
 import org.wamblee.photos.model.Album;
 import org.wamblee.security.authentication.UserAdministration;
 
@@ -31,18 +34,40 @@ import org.wamblee.security.authentication.UserAdministration;
 @Startup
 public class Initializer {
 
-    @Inject
-    private UserAdministration userAdmin;
+    private static final Logger LOGGER = Logger.getLogger(Initializer.class
+        .getName());
 
-    @Inject
-    @AllPhotos
-    private Album album;
+    /**
+     * We need this helper to do initialization of the beans from within the
+     * post construct method. Injecting these objects into the initializer class
+     * will lead to initialization outside of a transactional context and this
+     * is does not work because and entity manager is required.
+     * 
+     * @author Erik Brakkee
+     * 
+     */
+    public static class Helper {
+        @Inject
+        private UserAdministration userAdmin;
 
-    @PostConstruct
-    public void init() {
-        System.out.println("Photo application initializing");
+        @Inject
+        @AllPhotos
+        private Album album;
 
-        userAdmin.getUserCount();
-        album.size();
+        public void init() {
+            userAdmin.getUserCount();
+            album.size();
+        }
+    }
+
+    @PostConstruct
+    public void scheduleInit() {
+        LOGGER.info("Photo application initializing");
+        // timerService.createTimer(1000, 1000, null);
+        LOGGER.info("Initializing photo application");
+        Helper helper = new Helper();
+        InjectorBuilder.getInjector().inject(helper);
+        helper.init();
+        LOGGER.info("Initialized photo application");
     }
 }