Package org.locationtech.udig.catalog.internal.arcsde

Source Code of org.locationtech.udig.catalog.internal.arcsde.ArcSDEVectorService

/*
*    uDig - User Friendly Desktop Internet GIS client
*    http://udig.refractions.net
*    (C) 2010, Refractions Research Inc.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* (http://www.eclipse.org/legal/epl-v10.html), and the Refractions BSD
* License v1.0 (http://udig.refractions.net/files/bsd3-v10.html).
*/
package org.locationtech.udig.catalog.internal.arcsde;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.locationtech.udig.catalog.IGeoResource;

import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.NullProgressMonitor;
import org.geotools.arcsde.ArcSDEDataStoreFactory;
import org.geotools.arcsde.data.ArcSDEDataStore;
import org.geotools.arcsde.data.ArcSDEDataStoreConfig;
import org.geotools.arcsde.session.ISessionPool;
import org.geotools.data.DataStore;

/**
* Connect to ArcSDE and list Vector contents.
*
* @author Gabriel Roldan
* @since 1.2
*/
class ArcSDEVectorService extends ArcSDEService {

    private volatile ArcSDEDataStore ds;

    /**
     * Construct <code>PostGISServiceImpl</code>.
     *
     * @param arg1
     * @param params
     */
    public ArcSDEVectorService( ArcServiceImpl service ) {
        super(service);
    }

    @Override
    protected List<IGeoResource> createMembers( IProgressMonitor monitor ) throws IOException {
        getDS(null); // load ds

        String[] typenames = ds.getTypeNames();
        List<IGeoResource> members = new ArrayList<IGeoResource>(typenames.length);

        ArcSDEVectorGeoResource resource;
        for( int i = 0; i < typenames.length; i++ ) {
            resource = new ArcSDEVectorGeoResource(service, typenames[i]);
            members.add(resource);
        }
        return members;
    }

    /**
     * This method will lazily connect to ArcSDE making use of the connection parameters.
     *
     * @param monitor
     * @return
     * @throws IOException
     */
    ArcSDEDataStore getDS( IProgressMonitor monitor ) throws IOException {
        if (monitor == null) {
            monitor = new NullProgressMonitor();
        }
        if (ds == null) {
            synchronized (ArcSDEDataStoreFactory.class) {
                // please see WFS for a better example
                if (ds == null) {
                    final ISessionPool sessionPool = getSessionPool();
                    try {
                        ds = connect(sessionPool, monitor);
                    } catch (IOException e) {
                        throw e;
                    }
                }
            }
            // IResolveDelta delta = new ResolveDelta(this, IResolveDelta.Kind.CHANGED);
            // ((CatalogImpl) CatalogPlugin.getDefault().getLocalCatalog())
            // .fire(new ResolveChangeEvent(this, IResolveChangeEvent.Type.POST_CHANGE, delta));
        }
        return ds;
    }

    private ArcSDEDataStore connect( final ISessionPool sessionPool, IProgressMonitor monitor )
            throws IOException {
        if (monitor == null) {
            monitor = new NullProgressMonitor();
        }

        ArcSDEDataStoreConfig dsConfig = service.getDataStoreConfig();
        String namespaceUri = dsConfig.getNamespaceUri();
        String versionName = dsConfig.getVersion();
        boolean allowNonSpatialTables = dsConfig.isAllowNonSpatialTables();
        ArcSDEDataStore ds = new ArcSDEDataStore(sessionPool, namespaceUri, versionName,
                allowNonSpatialTables);
        return ds;
    }

    public DataStore getDataStore( IProgressMonitor monitor ) throws IOException {
        return getDS(monitor);
    }

}
TOP

Related Classes of org.locationtech.udig.catalog.internal.arcsde.ArcSDEVectorService

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.