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

com.stormpath.sdk.ds.DataStore Maven / Gradle / Ivy

/*
 * Copyright 2013 Stormpath, Inc.
 *
 * 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 com.stormpath.sdk.ds;

import com.stormpath.sdk.api.ApiKey;
import com.stormpath.sdk.cache.CacheManager;
import com.stormpath.sdk.query.Options;
import com.stormpath.sdk.resource.Resource;

/**
 * A {@code DataStore} is the liaison between client SDK components and the raw Stormpath REST API.  It is responsible
 * for converting SDK objects (Account, Directory, Group instances, etc) into REST HTTP requests, executing those
 * requests, and converting REST HTTP responses back into SDK objects.
 *
 * @since 0.1
 */
public interface DataStore {

    /**
     * Instantiates and returns a new instance of the specified Resource type.  The instance is merely instantiated and
     * is not saved/synchronized with the server in any way. 

This method effectively replaces the {@code new} * keyword that would have been used otherwise if the concrete implementation was known (Resource implementation * classes are intentionally not exposed to SDK end-users). * * @param clazz the Resource class to instantiate. * @param the Resource sub-type * @return a new instance of the specified Resource. */ T instantiate(Class clazz); /** * Looks up (retrieves) the resource at the specified {@code href} URL and returns the resource as an instance of * the specified {@code class}.

The {@code Class} argument must represent an interface that is a sub-interface * of {@link Resource}, for example {@link com.stormpath.sdk.account.Account Account}, {@link * com.stormpath.sdk.directory.Directory Directory}, etc. * * @param href the resource URL of the resource to retrieve * @param clazz the {@link Resource} sub-interface to instantiate * @param type parameter indicating the returned value is a {@link Resource} instance. * @return an instance of the specified class based on the data returned from the specified {@code href} URL. */ T getResource(String href, Class clazz); /** * Retrieves the resource at the specified {@code href} according to the specified {@code Options} and returns the * resource as an instance of the specified {@code clazz}. * * @param href the URL of the resource to retrieve * @param clazz the {@link Resource} sub-interface to instantiate * @param type parameter indicating the returned value is a {@link Resource} instance. * @param options the {@link Options} sub-interface with the properties to expand * @return an instance of the specified class based on the data returned from the specified {@code href} URL. * @since 1.0.RC4.6 */ T getResource(String href, Class clazz, O options); /** * Returns the ApiKey used to authenticate HTTPS requests sent to the Stormpath API server. * * @return the ApiKey used to authenticate HTTPS requests sent to the Stormpath API server. * @since 1.0.RC3 */ ApiKey getApiKey(); /** * Returns the CacheManager used to improve data store performance. * * @return the CacheManager used to improve data store performance. * @since 1.0.RC3 */ CacheManager getCacheManager(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy