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

com.microsoft.sqlserver.jdbc.osgi.Activator Maven / Gradle / Ivy

There is a newer version: 12.9.0.jre11-preview
Show newest version
/*
 * Microsoft JDBC Driver for SQL Server Copyright(c) Microsoft Corporation All rights reserved. This program is made
 * available under the terms of the MIT License. See the LICENSE file in the project root for more information.
 */
package com.microsoft.sqlserver.jdbc.osgi;

import java.util.Dictionary;
import java.util.Hashtable;

import org.osgi.framework.BundleActivator;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceRegistration;
import org.osgi.service.jdbc.DataSourceFactory;

import com.microsoft.sqlserver.jdbc.SQLServerDriver;


/**
 * Allows plugins to register the driver as an OSGI Framework service.
 * 
 */
public class Activator implements BundleActivator {

    private ServiceRegistration service;

    /**
     * default constructor
     */
    public Activator() {
        // default constructor
    }

    @Override
    public void start(BundleContext context) throws Exception {
        Dictionary properties = new Hashtable<>();
        SQLServerDriver driver = new SQLServerDriver();
        properties.put(DataSourceFactory.OSGI_JDBC_DRIVER_CLASS, driver.getClass().getName());
        properties.put(DataSourceFactory.OSGI_JDBC_DRIVER_NAME, "Microsoft JDBC Driver for SQL Server");
        properties.put(DataSourceFactory.OSGI_JDBC_DRIVER_VERSION,
                driver.getMajorVersion() + "." + driver.getMinorVersion());
        properties.put(DataSourceFactory.OSGI_JDBC_CAPABILITY,
                new String[] {DataSourceFactory.OSGI_JDBC_CAPABILITY_DRIVER,
                        DataSourceFactory.OSGI_JDBC_CAPABILITY_DATASOURCE,
                        DataSourceFactory.OSGI_JDBC_CAPABILITY_CONNECTIONPOOLDATASOURCE,
                        DataSourceFactory.OSGI_JDBC_CAPABILITY_XADATASOURCE});
        service = context.registerService(DataSourceFactory.class, new SQLServerDataSourceFactory(), properties);
        SQLServerDriver.register();
    }

    @Override
    public void stop(BundleContext context) throws Exception {
        if (service != null) {
            service.unregister();
        }
        SQLServerDriver.deregister();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy