summaryrefslogtreecommitdiff
path: root/modules/io_codec/c++/rpc.hpp
blob: 547eea3b3a32f72995682a9a9eeb26b287baec14 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#pragma once

#include <forstio/id.hpp>
#include <forstio/codec/data.hpp>
#include <forstio/async/async.hpp>

#include <forstio/codec/interface.hpp>

namespace saw {

/**
 * Representing data on the remote
 */
template<typename T, typename Remote>
class remote_data {
private:
	id<T> id_;
public:
	remote_data(const id<T>& id):
		id_{id}
	{}

	/**
	 * Wait until data arrives
	 */
	error_or<data<T>> wait(wait_scope& wait);

	/**
	 * Asynchronously wait for a result
	 */
	conveyor<data<T>> on_receive();
};

/**
 * Client RPC reference structure
 */
template<typename Iface, typename Encode, typename Remote>
class rpc_client {
	/**
	 * request the data from the remote
	 */
	template<typename IdT>
	remote_data<IdT, Remote> request_data(id<IdT> data);
		
	/** @todo
	 * Determine type based on Name
	 */
	/*
	template<string_literal Name>
	error_or<
		id<
			typename schema_member_type<Name, Iface>::type
		>
	> call(data_or_id<Input> inp);
	*/
};

/**
 * Implementation of a remote server on the backend
 */
template<typename Iface, typename Encode, typename Remote>
class rpc_server {
private:
	interface<Iface, Encode> iface_;
public:
	rpc_server(interface<Iface, Encode> iface):
		iface_{std::move(iface)}
	{}
};

/**
 * Representation of a remote.
 * Partially similar to a network address
 */
template<typename Remote>
class remote_address {
	static_assert(always_false<Remote>, "Type of remote not supported");


};

/**
 * Reference Backend structure
 */
template<typename Remote>
class remote {
	static_assert(always_false<Remote>, "Type of backend not supported");

	/**
	 * Resolves an address for the remote
	 */
	conveyor<remote_address<Remote>> resolve_address();

	/**
	 * Connect to a remote
	 */
	template<typename Iface, typename Encode>
	conveyor<rpc_client<Iface, Encode, Remote>> connect(const remote_address<Remote>& addr);

	/**
	 * Start listening
	 */
	template<typename Iface, typename Encode>
	rpc_server<Iface, Encode, Remote> listen();
};
}