/*****************************************************************
* 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.cayenne.configuration.rop.client;
import org.apache.cayenne.configuration.CayenneRuntime;
import org.apache.cayenne.di.Module;
import org.apache.cayenne.remote.ClientConnection;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Map;
import static java.util.Arrays.asList;
/**
* A user application entry point to Cayenne stack on the ROP client.
*
* @since 3.1
* @since 4.0 preferred way to create this class is with {@link ClientRuntime#builder()} method.
*/
public class ClientRuntime extends CayenneRuntime {
/**
* @since 4.0 moved from deprecated ClientLocalRuntime class
*/
public static final String CLIENT_SERVER_CHANNEL_KEY = "client-server-channel";
/**
* Creates new builder of client runtime
* @return client runtime builder
*
* @since 4.0
*/
public static ClientRuntimeBuilder builder() {
return new ClientRuntimeBuilder();
}
@Deprecated
private static Collection<Module> collectModules(Map<String, String> properties, Module... extraModules) {
Collection<Module> modules = extraModules != null ? asList(extraModules) : Collections.<Module>emptyList();
return collectModules(properties, modules);
}
@Deprecated
private static Collection<Module> collectModules(Map<String, String> properties, Collection<Module> extraModules) {
Collection<Module> modules = new ArrayList<>();
modules.add(new ClientModule(properties));
if(extraModules != null) {
modules.addAll(extraModules);
}
return modules;
}
/**
* Creates a client runtime configuring it with a standard set of services
* contained in {@link ClientModule}. CayenneClientModule is created based
* on a set of properties that contain things like connection information,
* etc. Recognized property keys are defined in {@link ClientModule}. An
* optional array of extra modules may contain service overrides and/or user
* services.
*
* @deprecated since 4.0, use {@link ClientRuntime#builder()} instead.
*/
@Deprecated
public ClientRuntime(Map<String, String> properties, Collection<Module> extraModules) {
this(collectModules(properties, extraModules));
}
/**
* Creates a client runtime configuring it with a standard set of services
* contained in {@link ClientModule}. CayenneClientModule is created based
* on a set of properties that contain things like connection information,
* etc. Recognized property keys are defined in {@link ClientModule}. An
* optional collection of extra modules may contain service overrides and/or
* user services.
*
* @deprecated since 4.0, use {@link ClientRuntime#builder()} instead.
*/
@Deprecated
public ClientRuntime(Map<String, String> properties, Module... extraModules) {
this(collectModules(properties, extraModules));
}
/**
* @since 4.0
*/
protected ClientRuntime(Collection<Module> modules) {
super(modules);
}
public ClientConnection getConnection() {
return injector.getInstance(ClientConnection.class);
}
}