mirror of
				https://github.com/ton-blockchain/ton
				synced 2025-03-09 15:40:10 +00:00 
			
		
		
		
	* Accelerator: partial fullnodes 1) Node can monitor a subset of shards 2) New archive slice format (sharded) 3) Validators are still required to have all shards 4) Support partial liteservers in lite-client, blockchain explorer, tonlib 5) Proxy liteserver * Fix compilation error
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|     This file is part of TON Blockchain Library.
 | |
| 
 | |
|     TON Blockchain Library is free software: you can redistribute it and/or modify
 | |
|     it under the terms of the GNU Lesser General Public License as published by
 | |
|     the Free Software Foundation, either version 2 of the License, or
 | |
|     (at your option) any later version.
 | |
| 
 | |
|     TON Blockchain Library is distributed in the hope that it will be useful,
 | |
|     but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|     GNU Lesser General Public License for more details.
 | |
| 
 | |
|     You should have received a copy of the GNU Lesser General Public License
 | |
|     along with TON Blockchain Library.  If not, see <http://www.gnu.org/licenses/>.
 | |
| */
 | |
| #pragma once
 | |
| #include "td/actor/actor.h"
 | |
| #include "ton/ton-types.h"
 | |
| #include "adnl/adnl-ext-client.h"
 | |
| #include "query-utils.hpp"
 | |
| 
 | |
| namespace liteclient {
 | |
| class ExtClient : public td::actor::Actor {
 | |
|  public:
 | |
|   class Callback {
 | |
|    public:
 | |
|     virtual ~Callback() = default;
 | |
|   };
 | |
| 
 | |
|   virtual void send_query(std::string name, td::BufferSlice data, td::Timestamp timeout,
 | |
|                           td::Promise<td::BufferSlice> promise) = 0;
 | |
|   virtual void send_query_to_server(std::string name, td::BufferSlice data, size_t server_idx, td::Timestamp timeout,
 | |
|                                     td::Promise<td::BufferSlice> promise) {
 | |
|     promise.set_error(td::Status::Error("not supported"));
 | |
|   }
 | |
|   virtual void get_servers_status(td::Promise<std::vector<bool>> promise) {
 | |
|     promise.set_error(td::Status::Error("not supported"));
 | |
|   }
 | |
|   virtual void reset_servers() {
 | |
|   }
 | |
| 
 | |
|   static td::actor::ActorOwn<ExtClient> create(ton::adnl::AdnlNodeIdFull dst, td::IPAddress dst_addr,
 | |
|                                                td::unique_ptr<Callback> callback);
 | |
|   static td::actor::ActorOwn<ExtClient> create(std::vector<LiteServerConfig> liteservers,
 | |
|                                                td::unique_ptr<Callback> callback, bool connect_to_all = false);
 | |
| };
 | |
| }  // namespace liteclient
 |