mirror of
				https://github.com/ton-blockchain/ton
				synced 2025-03-09 15:40:10 +00:00 
			
		
		
		
	Add send_mode param to tonlib_api msg.message (send_mode=-1 - use default)
This commit is contained in:
		
							parent
							
								
									72cf905fd1
								
							
						
					
					
						commit
						c1a733c0f0
					
				
					 6 changed files with 10 additions and 3 deletions
				
			
		| 
						 | 
					@ -36,6 +36,7 @@ class WalletInterface : public SmartContract {
 | 
				
			||||||
  struct Gift {
 | 
					  struct Gift {
 | 
				
			||||||
    block::StdAddress destination;
 | 
					    block::StdAddress destination;
 | 
				
			||||||
    td::int64 gramms;
 | 
					    td::int64 gramms;
 | 
				
			||||||
 | 
					    td::int32 send_mode{-1};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bool is_encrypted{false};
 | 
					    bool is_encrypted{false};
 | 
				
			||||||
    std::string message;
 | 
					    std::string message;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -40,6 +40,9 @@ td::Result<td::Ref<vm::Cell>> WalletV3::make_a_gift_message(const td::Ed25519::P
 | 
				
			||||||
    if (gift.gramms == -1) {
 | 
					    if (gift.gramms == -1) {
 | 
				
			||||||
      send_mode += 128;
 | 
					      send_mode += 128;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					    if (gift.send_mode > -1) {
 | 
				
			||||||
 | 
					      send_mode = gift.send_mode;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    cb.store_long(send_mode, 8).store_ref(create_int_message(gift));
 | 
					    cb.store_long(send_mode, 8).store_ref(create_int_message(gift));
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -105,7 +105,7 @@ msg.dataDecrypted proof:bytes data:msg.Data = msg.DataDecrypted;
 | 
				
			||||||
msg.dataEncryptedArray elements:vector<msg.dataEncrypted> = msg.DataEncryptedArray;
 | 
					msg.dataEncryptedArray elements:vector<msg.dataEncrypted> = msg.DataEncryptedArray;
 | 
				
			||||||
msg.dataDecryptedArray elements:vector<msg.dataDecrypted> = msg.DataDecryptedArray;
 | 
					msg.dataDecryptedArray elements:vector<msg.dataDecrypted> = msg.DataDecryptedArray;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
msg.message destination:accountAddress public_key:string amount:int64 data:msg.Data = msg.Message;
 | 
					msg.message destination:accountAddress public_key:string amount:int64 data:msg.Data send_mode:int32 = msg.Message;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
//
 | 
					//
 | 
				
			||||||
// DNS
 | 
					// DNS
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
										
											Binary file not shown.
										
									
								
							| 
						 | 
					@ -2559,6 +2559,7 @@ class GenericCreateSendGrams : public TonlibQueryActor {
 | 
				
			||||||
  struct Action {
 | 
					  struct Action {
 | 
				
			||||||
    block::StdAddress destination;
 | 
					    block::StdAddress destination;
 | 
				
			||||||
    td::int64 amount;
 | 
					    td::int64 amount;
 | 
				
			||||||
 | 
					    td::int32 send_mode{-1};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bool is_encrypted{false};
 | 
					    bool is_encrypted{false};
 | 
				
			||||||
    bool should_encrypt;
 | 
					    bool should_encrypt;
 | 
				
			||||||
| 
						 | 
					@ -2610,6 +2611,7 @@ class GenericCreateSendGrams : public TonlibQueryActor {
 | 
				
			||||||
      auto key = td::Ed25519::PublicKey(td::SecureString(public_key.key));
 | 
					      auto key = td::Ed25519::PublicKey(td::SecureString(public_key.key));
 | 
				
			||||||
      res.o_public_key = std::move(key);
 | 
					      res.o_public_key = std::move(key);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					    res.send_mode = message.send_mode_;
 | 
				
			||||||
    auto status = downcast_call2<td::Status>(
 | 
					    auto status = downcast_call2<td::Status>(
 | 
				
			||||||
        *message.data_, td::overloaded(
 | 
					        *message.data_, td::overloaded(
 | 
				
			||||||
                            [&](tonlib_api::msg_dataRaw& text) {
 | 
					                            [&](tonlib_api::msg_dataRaw& text) {
 | 
				
			||||||
| 
						 | 
					@ -3045,6 +3047,7 @@ class GenericCreateSendGrams : public TonlibQueryActor {
 | 
				
			||||||
      auto& destination = destinations_[i];
 | 
					      auto& destination = destinations_[i];
 | 
				
			||||||
      gift.destination = destinations_[i]->get_address();
 | 
					      gift.destination = destinations_[i]->get_address();
 | 
				
			||||||
      gift.gramms = action.amount;
 | 
					      gift.gramms = action.amount;
 | 
				
			||||||
 | 
					      gift.send_mode = action.send_mode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      // Temporary turn off this dangerous transfer
 | 
					      // Temporary turn off this dangerous transfer
 | 
				
			||||||
      if (false && action.amount == source_->get_balance()) {
 | 
					      if (false && action.amount == source_->get_balance()) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1096,7 +1096,7 @@ class TonlibCli : public td::actor::Actor {
 | 
				
			||||||
    std::vector<tonlib_api::object_ptr<tonlib_api::msg_message>> messages;
 | 
					    std::vector<tonlib_api::object_ptr<tonlib_api::msg_message>> messages;
 | 
				
			||||||
    messages.push_back(
 | 
					    messages.push_back(
 | 
				
			||||||
        make_object<tonlib_api::msg_message>(channels_[pchan_id].to_address(), "", value,
 | 
					        make_object<tonlib_api::msg_message>(channels_[pchan_id].to_address(), "", value,
 | 
				
			||||||
                                             make_object<tonlib_api::msg_dataRaw>(query->body_, query->init_state_)));
 | 
					                                             make_object<tonlib_api::msg_dataRaw>(query->body_, query->init_state_), -1));
 | 
				
			||||||
    auto action = make_object<tonlib_api::actionMsg>(std::move(messages), true);
 | 
					    auto action = make_object<tonlib_api::actionMsg>(std::move(messages), true);
 | 
				
			||||||
    send_query(
 | 
					    send_query(
 | 
				
			||||||
        make_object<tonlib_api::createQuery>(addr.input_key(), std::move(addr.address), 60, std::move(action), nullptr),
 | 
					        make_object<tonlib_api::createQuery>(addr.input_key(), std::move(addr.address), 60, std::move(action), nullptr),
 | 
				
			||||||
| 
						 | 
					@ -2217,7 +2217,7 @@ class TonlibCli : public td::actor::Actor {
 | 
				
			||||||
        data = make_object<tonlib_api::msg_dataText>(message.str());
 | 
					        data = make_object<tonlib_api::msg_dataText>(message.str());
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      messages.push_back(
 | 
					      messages.push_back(
 | 
				
			||||||
          make_object<tonlib_api::msg_message>(std::move(address.address), "", amount.nano, std::move(data)));
 | 
					          make_object<tonlib_api::msg_message>(std::move(address.address), "", amount.nano, std::move(data), -1));
 | 
				
			||||||
      return td::Status::OK();
 | 
					      return td::Status::OK();
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue