You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@wink.apache.org by gp...@apache.org on 2013/08/23 20:38:45 UTC

svn commit: r1516974 - in /wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension: JAXRSJCDICustomInjectionTarget.java WinkInjectionTarget.java

Author: gpetracek
Date: Fri Aug 23 18:38:44 2013
New Revision: 1516974

URL: http://svn.apache.org/r1516974
Log:
WINK-409 cleanup

Added:
    wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension/WinkInjectionTarget.java
Removed:
    wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension/JAXRSJCDICustomInjectionTarget.java

Added: wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension/WinkInjectionTarget.java
URL: http://svn.apache.org/viewvc/wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension/WinkInjectionTarget.java?rev=1516974&view=auto
==============================================================================
--- wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension/WinkInjectionTarget.java (added)
+++ wink/2.x/trunk/wink-cdi-server/src/main/java/org/apache/wink/cdi/server/internal/extension/WinkInjectionTarget.java Fri Aug 23 18:38:44 2013
@@ -0,0 +1,112 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you 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.apache.wink.cdi.server.internal.extension;
+
+import org.apache.wink.common.internal.i18n.Messages;
+import org.apache.wink.common.internal.lifecycle.CreationUtils;
+import org.apache.wink.common.internal.registry.metadata.ApplicationMetadataCollector;
+import org.apache.wink.common.internal.registry.metadata.ClassMetadata;
+import org.apache.wink.common.internal.registry.metadata.ProviderMetadataCollector;
+import org.apache.wink.common.internal.registry.metadata.ResourceMetadataCollector;
+import org.apache.wink.common.internal.runtime.RuntimeContextTLS;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import javax.enterprise.context.spi.CreationalContext;
+import javax.enterprise.inject.spi.InjectionPoint;
+import javax.enterprise.inject.spi.InjectionTarget;
+import java.io.IOException;
+import java.security.AccessController;
+import java.security.PrivilegedActionException;
+import java.security.PrivilegedExceptionAction;
+import java.util.Set;
+
+class WinkInjectionTarget<T> implements InjectionTarget<T> {
+    private static final Logger logger = LoggerFactory.getLogger(WinkInjectionTarget.class);
+
+    private ClassMetadata classMetadata;
+
+    private final InjectionTarget<T> delegate;
+
+    WinkInjectionTarget(InjectionTarget<T> delegate) {
+        logger.trace("constructor({}) entry", delegate);
+        this.delegate = delegate;
+        logger.trace("constructor() exit");
+    }
+
+    public void inject(final T instance, final CreationalContext<T> creationalContext) {
+        logger.trace("inject({}, {}) entry", instance, creationalContext);
+        try {
+            AccessController.doPrivileged(new PrivilegedExceptionAction<Object>() {
+
+                public Object run() throws PrivilegedActionException {
+                    if (classMetadata == null) {
+                        logger.trace("Collecting classMetadata for {}", this);
+                        classMetadata = collectClassMetadata(instance.getClass());
+                    }
+                    logger.trace("Calling CreationUtils.injectFields for instance");
+                    try {
+                        CreationUtils.injectFields(instance, classMetadata, RuntimeContextTLS.getRuntimeContext());
+                    } catch (IOException e) {
+                        throw new PrivilegedActionException(e);
+                    }
+                    return null;
+                }
+            });
+        } catch (Exception e) {
+            logger.warn(Messages.getMessage("exceptionDuringInjection"), e);
+        }
+
+        logger.trace("calling delegate.inject(instance, creationalContext)");
+        delegate.inject(instance, creationalContext);
+        logger.trace("inject() exit");
+    }
+
+    public void postConstruct(T instance) {
+        delegate.postConstruct(instance);
+    }
+
+    public void preDestroy(T instance) {
+        delegate.preDestroy(instance);
+    }
+
+    public void dispose(T instance) {
+        delegate.dispose(instance);
+    }
+
+    public Set<InjectionPoint> getInjectionPoints() {
+        return delegate.getInjectionPoints();
+    }
+
+    public T produce(CreationalContext<T> creationalContext) {
+        return delegate.produce(creationalContext);
+    }
+
+    private static <T> ClassMetadata collectClassMetadata(final Class<T> cls) {
+        ClassMetadata classMetadata = null;
+        if (ProviderMetadataCollector.isProvider(cls)) {
+            classMetadata = ProviderMetadataCollector.collectMetadata(cls);
+        } else if (ResourceMetadataCollector.isResource(cls)) {
+            classMetadata = ResourceMetadataCollector.collectMetadata(cls);
+        } else if (ApplicationMetadataCollector.isApplication(cls)) {
+            classMetadata = ApplicationMetadataCollector.collectMetadata(cls);
+        }
+        return classMetadata;
+    }
+}