All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.krotscheck.jersey2.hibernate.HibernateFeature Maven / Gradle / Ivy

There is a newer version: 2.1.1
Show newest version
/*
 * Copyright (c) 2014 Michael Krotscheck
 *
 * 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 net.krotscheck.jersey2.hibernate;


import net.krotscheck.jersey2.hibernate.factory.FulltextSearchFactoryFactory;
import net.krotscheck.jersey2.hibernate.factory.FulltextSessionFactory;
import net.krotscheck.jersey2.hibernate.factory.HibernateConfigurationFactory;
import net.krotscheck.jersey2.hibernate.factory.HibernateSessionFactory;
import net.krotscheck.jersey2.hibernate.factory.HibernateSessionFactoryFactory;
import net.krotscheck.jersey2.hibernate.lifecycle.SearchIndexContextListener;

import javax.ws.rs.core.Feature;
import javax.ws.rs.core.FeatureContext;

/**
 * This jersey2 feature will ensure that there is always a hibernate session
 * available in the current request context. It is important to keep mind of
 * scope here: Sessions are scoped by request, while the SessionFactory is
 * scoped as a singleton. In other words, if you need a session in a context
 * lifecycle listener, then you should construct it by injecting the
 * SessionFactory first.
 *
 * @author Michael Krotscheck
 */
public final class HibernateFeature implements Feature {

    /**
     * Register the HibernateFeature with the current application context.
     *
     * @param context The application context.
     * @return Always true.
     */
    @Override
    public boolean configure(final FeatureContext context) {

        // Hibernate configuration.
        context.register(new HibernateSessionFactory.Binder());
        context.register(new HibernateSessionFactoryFactory.Binder());
        context.register(new HibernateConfigurationFactory.Binder());
        context.register(new FulltextSearchFactoryFactory.Binder());
        context.register(new FulltextSessionFactory.Binder());

        // Migration binder
        context.register(new SearchIndexContextListener.Binder());

        return true;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy