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

io.proximax.xpx.factory.ConnectionFactory Maven / Gradle / Ivy

There is a newer version: 0.1.0-beta.10
Show newest version
/*
 * Copyright 2018 ProximaX Limited
 *
 * 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 io.proximax.xpx.factory;

import org.nem.core.connect.ErrorResponseDeserializerUnion;
import org.nem.core.connect.HttpMethodClient;
import org.nem.core.connect.client.DefaultAsyncNemConnector;
import org.nem.core.model.Account;
import org.nem.core.model.NetworkInfo;
import org.nem.core.model.NetworkInfos;
import org.nem.core.node.ApiId;
import org.nem.core.node.NodeEndpoint;

import io.ipfs.api.IPFS;
import io.ipfs.multiaddr.MultiAddress;








/**
 * A factory for creating Connector objects.
 */
public class ConnectionFactory {

	/** The Constant CLIENT. */
	private static final HttpMethodClient CLIENT = createHttpMethodClient();

	/**
	 * Creates a new Connector object.
	 *
	 * @return the default async proximax connector
	 */
	public static DefaultAsyncNemConnector createConnector() {
		final DefaultAsyncNemConnector connector = new DefaultAsyncNemConnector<>(CLIENT, r -> {
			throw new RuntimeException(r.toString());
		});
		connector.setAccountLookup(Account::new);
		return connector;
	}
	
	/**
	 * Creates a new Connection object.
	 *
	 * @param network the proximax network
	 * @param protocol the protocol
	 * @param domainOrIp the domain or ip
	 * @param port the port
	 * @param wsPort the ws port
	 * @return the node endpoint
	 */
	public static NodeEndpoint createNemNodeConnection(String network, String protocol, String domainOrIp, int port, String wsPort) {
		setNetwork(network);
		return new NodeEndpoint(protocol, domainOrIp, port);
	}
	
	
	/**
	 * Creates a new Connection object.
	 *
	 * @param network the network
	 * @param protocol the protocol
	 * @param domainOrIp the domain or ip
	 * @param port the port
	 * @return the node endpoint
	 */
	public static NodeEndpoint createNemNodeConnection(String network, String protocol, String domainOrIp, int port) {
		setNetwork(network);
		return new NodeEndpoint(protocol, domainOrIp, port);
	}
	
	/**
	 * Creates a new Connection object.
	 *
	 * @param multiAddress the multi address
	 * @return the ipfs
	 */
	public static IPFS createIPFSNodeConnection(String multiAddress) {
		return new IPFS(new MultiAddress(multiAddress));
	}
	
	public static void setNetwork(String network) {
		NetworkInfo networkInfo = NetworkInfos.getTestNetworkInfo();
		if(network.equals("mainnet")) {
			networkInfo = NetworkInfos.getMainNetworkInfo();
		}else if(network.equals("mijinnet")) {
			networkInfo = NetworkInfos.getMijinNetworkInfo();
		}
		NetworkInfos.setDefault(networkInfo);
	}

	/**
	 * Creates a new Connector object.
	 *
	 * @return the http method client< error response deserializer union>
	 */
	private static HttpMethodClient createHttpMethodClient() {
		final int connectionTimeout = 4000;
		final int socketTimeout = 10000;
		final int requestTimeout = 30000;
		return new HttpMethodClient<>(connectionTimeout, socketTimeout, requestTimeout);
	}
	

	
	
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy