ton-client-ruby 1.0.0 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 0321af077acd0b4c971b583f6448bbb0c9633abfd72be60a9a442bd595f74bc2
4
- data.tar.gz: 3e2bca8f73c5dd23dc5c60be5655d2f777d58a5870d1176d3633ef69d0eb52b4
3
+ metadata.gz: d7dfd053a1c976028bc40dfe2cf9bb4750beee2688428ae7b8cfc9ff7e3c4d8d
4
+ data.tar.gz: 651588ea67891811a9a847dda130c5cc2c6d1aac770213254b16c47ce4384238
5
5
  SHA512:
6
- metadata.gz: 242a9a7821f494ef4165d3c3b25d680c194b9be860a766fab753d44b05332a1c5a14e5674347a0af31f52af34e751a980352070000c1cadd67b4949e88faba11
7
- data.tar.gz: fdca0400955e2d5010bde1ed0ca3b938f43a9198c315e8bed2cca7d9518bca57ee02f1447576a5dd52b6a1c03b26601fbd641d2c3d3b099ae68beec2ffacef1c
6
+ metadata.gz: 30e93f4c4d28c0b0d8af0766a5d9f632b1a3263ff63ac0edb312bb552b28404f5a2c5129fc418b9a18c440e7a6e6be8e18886c8377d83b28d58157d9052572e1
7
+ data.tar.gz: 88ea3e6773d2d005a48ffdc7cb1ca4992f4a0955606814ceaed33c9f391b4842fac02d8043c35496fd69feb9eea70c34080b6c0b4f6b73eddf10122818c4dc46
@@ -0,0 +1,38 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require File.dirname(__FILE__) + '/../code_generator/api_converter.rb'
4
+ require File.dirname(__FILE__) + '/../code_generator/code_generator.rb'
5
+
6
+ GEM_DIR = File.dirname(__FILE__) + '/..'
7
+
8
+ if ARGV[0] == 'update'
9
+ if !ARGV[1]
10
+ puts ''
11
+ puts ''
12
+ p "PLEASE DOWNLOAD api.json from https://github.com/tonlabs/TON-SDK/blob/master/tools/api.json and pass as second parameter."
13
+ p "Example: ton-client-ruby update ./api.json"
14
+ puts ''
15
+ return
16
+ end
17
+ api_json_path = ARGV[1]
18
+ json = ''
19
+ if File.exists?(api_json_path)
20
+ json = File.read(api_json_path)
21
+ else
22
+ p "Current directory: #{Dir.pwd}. File #{api_json_path} is not exist"
23
+ exit 0
24
+ end
25
+ converter = ApiConverter.new(json)
26
+ types = converter.convert
27
+ generator = CodeGenerator.new(types, GEM_DIR)
28
+ generator.generate_self_code
29
+ elsif ARGV[0] == 'update' && ARGV[1] == nil
30
+ p 'soon from github'
31
+ elsif ARGV[0] == 'setup'
32
+ raise "\nPLEASE INSTALL RUST TO YOUR SYSTEM. \nTry this command: \ncurl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh" if `which rustc`.strip.empty?
33
+ system("cd #{GEM_DIR} && git clone https://github.com/tonlabs/TON-SDK ./TON-SDK")
34
+ system("cd #{GEM_DIR}/TON-SDK && git pull --ff-only")
35
+ system("cd #{GEM_DIR}/TON-SDK && cargo update")
36
+ system("cd #{GEM_DIR}/TON-SDK && cargo build --release")
37
+ puts "PATH TO YOR DYNAMIC LIBRARY IS: #{GEM_DIR}/TON-SDK/target/release/libton_client.dylib"
38
+ end
@@ -1,8 +1,11 @@
1
+ require 'bundler/setup'
2
+ Bundler.setup
1
3
  require 'ffi'
2
4
  require "base64"
3
5
  require 'json'
4
6
  require 'byebug'
5
7
  require 'dotenv'
8
+ require 'fileutils'
6
9
  require 'ton-client-ruby/Helpers/CommonHelpers.rb'
7
10
  require 'ton-client-ruby/Binding/struct.rb'
8
11
  require 'ton-client-ruby/Binding/binding.rb'
@@ -147,14 +147,11 @@ module TonClient
147
147
  end
148
148
 
149
149
  if string[:content].address > 1
150
- # string = string[:content].read_string(string[:len]).force_encoding('UTF-8') + ''
151
- # tc_destroy_string(tc_string_handle) if is_ref
152
- # return string
153
- return string[:content].read_string(string[:len]).force_encoding('UTF-8') + ''
150
+ string = string[:content].read_string(string[:len]).force_encoding('UTF-8') + ''
151
+ tc_destroy_string(tc_string_handle) if is_ref
152
+ return string
154
153
  end
155
154
  nil
156
- ensure
157
- tc_destroy_string(tc_string_handle) if is_ref
158
155
  end
159
156
 
160
157
  def self.read_string_to_hash(tc_string_handle_t_ref)
@@ -1,5 +1,5 @@
1
1
  module TonClient
2
-
2
+
3
3
  class Abi
4
4
  include CommonInstanceHelpers
5
5
 
@@ -11,42 +11,124 @@ module TonClient
11
11
  @core = core
12
12
  end
13
13
 
14
+ # INPUT: ParamsOfEncodeMessageBody
15
+ # abi: Value - # # Contract ABI.
16
+ # call_set: CallSet - # # Function call parameters. # # Must be specified in non deploy message.
17
+ # In case of deploy message contains parameters of constructor.
18
+ # is_internal: Boolean - # # True if internal message body must be encoded.
19
+ # signer: Signer - # # Signing parameters.
20
+ # processing_try_index: Number<Optional> - # # Processing try index. # # Used in message processing with retries.
21
+ # Encoder uses the provided try index to calculate messageexpiration time.
22
+ # Expiration timeouts will grow with every retry.
23
+ # Default value is 0.
24
+ # RESPONSE: ResultOfEncodeMessageBody
25
+ # body: String - # # Message body BOC encoded with `base64`.
26
+ # data_to_sign: String<Optional> - # # Optional data to sign. # # Encoded with `base64`.
27
+ # # Presents when `message` is unsigned. Can be used for externalmessage signing. Is this case you need to sing this data andproduce signed message using `abi.attach_signature`.
14
28
  def encode_message_body(payload, &block)
15
29
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
16
30
  end
17
31
 
32
+ # INPUT: ParamsOfAttachSignatureToMessageBody
33
+ # abi: Value - # # Contract ABI
34
+ # public_key: String - # # Public key. # # Must be encoded with `hex`.
35
+ # message: String - # # Unsigned message body BOC. # # Must be encoded with `base64`.
36
+ # signature: String - # # Signature. # # Must be encoded with `hex`.
37
+ # RESPONSE: ResultOfAttachSignatureToMessageBody
38
+ # body: String -
18
39
  def attach_signature_to_message_body(payload, &block)
19
40
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
20
41
  end
21
42
 
43
+ # INPUT: ParamsOfEncodeMessage
44
+ # abi: Value - # # Contract ABI.
45
+ # address: String<Optional> - # # Target address the message will be sent to. # # Must be specified in case of non-deploy message.
46
+ # deploy_set: DeploySet<Optional> - # # Deploy parameters. # # Must be specified in case of deploy message.
47
+ # call_set: CallSet<Optional> - # # Function call parameters. # # Must be specified in case of non-deploy message.
48
+ # In case of deploy message it is optional and contains parametersof the functions that will to be called upon deploy transaction.
49
+ # signer: Signer - # # Signing parameters.
50
+ # processing_try_index: Number<Optional> - # # Processing try index. # # Used in message processing with retries (if contract's ABI includes "expire" header).
51
+ # Encoder uses the provided try index to calculate messageexpiration time. The 1st message expiration time is specified inClient config.
52
+ # Expiration timeouts will grow with every retry.
53
+ # Retry grow factor is set in Client config:
54
+ # <.....add config parameter with default value here>Default value is 0.
55
+ # RESPONSE: ResultOfEncodeMessage
56
+ # message: String - # # Message BOC encoded with `base64`.
57
+ # data_to_sign: String<Optional> - # # Optional data to be signed encoded in `base64`. # # Returned in case of `Signer::External`. Can be used for externalmessage signing. Is this case you need to use this data to create signature andthen produce signed message using `abi.attach_signature`.
58
+ # address: String - # # Destination address.
59
+ # message_id: String - # # Message id.
22
60
  def encode_message(payload, &block)
23
61
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
24
62
  end
25
63
 
64
+ # INPUT: ParamsOfEncodeInternalMessage
65
+ # abi: Value<Optional> - # # Contract ABI. # # Can be None if both deploy_set and call_set are None.
66
+ # address: String<Optional> - # # Target address the message will be sent to. # # Must be specified in case of non-deploy message.
67
+ # src_address: String<Optional> - # # Source address of the message.
68
+ # deploy_set: DeploySet<Optional> - # # Deploy parameters. # # Must be specified in case of deploy message.
69
+ # call_set: CallSet<Optional> - # # Function call parameters. # # Must be specified in case of non-deploy message.
70
+ # In case of deploy message it is optional and contains parametersof the functions that will to be called upon deploy transaction.
71
+ # value: String - # # Value in nanotokens to be sent with message.
72
+ # bounce: Boolean<Optional> - # # Flag of bounceable message. # # Default is true.
73
+ # enable_ihr: Boolean<Optional> - # # Enable Instant Hypercube Routing for the message. # # Default is false.
74
+ # RESPONSE: ResultOfEncodeInternalMessage
75
+ # message: String - # # Message BOC encoded with `base64`.
76
+ # address: String - # # Destination address.
77
+ # message_id: String - # # Message id.
26
78
  def encode_internal_message(payload, &block)
27
79
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
28
80
  end
29
81
 
82
+ # INPUT: ParamsOfAttachSignature
83
+ # abi: Value - # # Contract ABI
84
+ # public_key: String - # # Public key encoded in `hex`.
85
+ # message: String - # # Unsigned message BOC encoded in `base64`.
86
+ # signature: String - # # Signature encoded in `hex`.
87
+ # RESPONSE: ResultOfAttachSignature
88
+ # message: String - # # Signed message BOC
89
+ # message_id: String - # # Message ID
30
90
  def attach_signature(payload, &block)
31
91
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
32
92
  end
33
93
 
94
+ # INPUT: ParamsOfDecodeMessage
95
+ # abi: Value - # # contract ABI
96
+ # message: String - # # Message BOC
97
+ # RESPONSE: DecodedMessageBody
98
+ # body_type: MessageBodyType - # # Type of the message body content.
99
+ # name: String - # # Function or event name.
100
+ # value: Value<Optional> - # # Parameters or result value.
101
+ # header: FunctionHeader<Optional> - # # Function header.
34
102
  def decode_message(payload, &block)
35
103
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
36
104
  end
37
105
 
106
+ # INPUT: ParamsOfDecodeMessageBody
107
+ # abi: Value - # # Contract ABI used to decode.
108
+ # body: String - # # Message body BOC encoded in `base64`.
109
+ # is_internal: Boolean - # # True if the body belongs to the internal message.
110
+ # RESPONSE: DecodedMessageBody
111
+ # body_type: MessageBodyType - # # Type of the message body content.
112
+ # name: String - # # Function or event name.
113
+ # value: Value<Optional> - # # Parameters or result value.
114
+ # header: FunctionHeader<Optional> - # # Function header.
38
115
  def decode_message_body(payload, &block)
39
116
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
40
117
  end
41
118
 
119
+ # INPUT: ParamsOfEncodeAccount
120
+ # state_init: StateInitSource - # # Source of the account state init.
121
+ # balance: BigInt<Optional> - # # Initial balance.
122
+ # last_trans_lt: BigInt<Optional> - # # Initial value for the `last_trans_lt`.
123
+ # last_paid: Number<Optional> - # # Initial value for the `last_paid`.
124
+ # boc_cache: BocCacheType<Optional> - # # Cache type to put the result. # # The BOC itself returned if no cache type provided
125
+ # RESPONSE: ResultOfEncodeAccount
126
+ # account: String - # # Account BOC encoded in `base64`.
127
+ # id: String - # # Account ID encoded in `hex`.
42
128
  def encode_account(payload, &block)
43
129
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
44
130
  end
131
+
45
132
  end
46
133
  end
47
134
 
48
-
49
-
50
-
51
-
52
-
@@ -1,5 +1,5 @@
1
1
  module TonClient
2
-
2
+
3
3
  class Boc
4
4
  include CommonInstanceHelpers
5
5
 
@@ -11,58 +11,105 @@ module TonClient
11
11
  @core = core
12
12
  end
13
13
 
14
+ # INPUT: ParamsOfParse
15
+ # boc: String - # # BOC encoded as base64
16
+ # RESPONSE: ResultOfParse
17
+ # parsed: Value - # # JSON containing parsed BOC
14
18
  def parse_message(payload, &block)
15
19
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
16
20
  end
17
21
 
22
+ # INPUT: ParamsOfParse
23
+ # boc: String - # # BOC encoded as base64
24
+ # RESPONSE: ResultOfParse
25
+ # parsed: Value - # # JSON containing parsed BOC
18
26
  def parse_transaction(payload, &block)
19
27
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
20
28
  end
21
29
 
30
+ # INPUT: ParamsOfParse
31
+ # boc: String - # # BOC encoded as base64
32
+ # RESPONSE: ResultOfParse
33
+ # parsed: Value - # # JSON containing parsed BOC
22
34
  def parse_account(payload, &block)
23
35
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
24
36
  end
25
37
 
38
+ # INPUT: ParamsOfParse
39
+ # boc: String - # # BOC encoded as base64
40
+ # RESPONSE: ResultOfParse
41
+ # parsed: Value - # # JSON containing parsed BOC
26
42
  def parse_block(payload, &block)
27
43
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
28
44
  end
29
45
 
46
+ # INPUT: ParamsOfParseShardstate
47
+ # boc: String - # # BOC encoded as base64
48
+ # id: String - # # Shardstate identificator
49
+ # workchain_id: Number - # # Workchain shardstate belongs to
50
+ # RESPONSE: ResultOfParse
51
+ # parsed: Value - # # JSON containing parsed BOC
30
52
  def parse_shardstate(payload, &block)
31
53
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
32
54
  end
33
55
 
56
+ # INPUT: ParamsOfGetBlockchainConfig
57
+ # block_boc: String - # # Key block BOC or zerostate BOC encoded as base64
58
+ # RESPONSE: ResultOfGetBlockchainConfig
59
+ # config_boc: String - # # Blockchain config BOC encoded as base64
34
60
  def get_blockchain_config(payload, &block)
35
61
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
36
62
  end
37
63
 
64
+ # INPUT: ParamsOfGetBocHash
65
+ # boc: String - # # BOC encoded as base64
66
+ # RESPONSE: ResultOfGetBocHash
67
+ # hash: String - # # BOC root hash encoded with hex
38
68
  def get_boc_hash(payload, &block)
39
69
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
40
70
  end
41
71
 
72
+ # INPUT: ParamsOfGetCodeFromTvc
73
+ # tvc: String - # # Contract TVC image encoded as base64
74
+ # RESPONSE: ResultOfGetCodeFromTvc
75
+ # code: String - # # Contract code encoded as base64
42
76
  def get_code_from_tvc(payload, &block)
43
77
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
44
78
  end
45
79
 
80
+ # INPUT: ParamsOfBocCacheGet
81
+ # boc_ref: String - # # Reference to the cached BOC
82
+ # RESPONSE: ResultOfBocCacheGet
83
+ # boc: String<Optional> - # # BOC encoded as base64.
46
84
  def cache_get(payload, &block)
47
85
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
48
86
  end
49
87
 
88
+ # INPUT: ParamsOfBocCacheSet
89
+ # boc: String - # # BOC encoded as base64 or BOC reference
90
+ # cache_type: BocCacheType - # # Cache type
91
+ # RESPONSE: ResultOfBocCacheSet
92
+ # boc_ref: String - # # Reference to the cached BOC
50
93
  def cache_set(payload, &block)
51
94
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
52
95
  end
53
96
 
97
+ # INPUT: ParamsOfBocCacheUnpin
98
+ # pin: String - # # Pinned name
99
+ # boc_ref: String<Optional> - # # Reference to the cached BOC. # # If it is provided then only referenced BOC is unpinned
54
100
  def cache_unpin(payload, &block)
55
101
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
56
102
  end
57
103
 
104
+ # INPUT: ParamsOfEncodeBoc
105
+ # builder: Array - # # Cell builder operations.
106
+ # boc_cache: BocCacheType<Optional> - # # Cache type to put the result. The BOC itself returned if no cache type provided.
107
+ # RESPONSE: ResultOfEncodeBoc
108
+ # boc: String - # # Encoded cell BOC or BOC cache key.
58
109
  def encode_boc(payload, &block)
59
110
  core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
60
111
  end
112
+
61
113
  end
62
114
  end
63
115
 
64
-
65
-
66
-
67
-
68
-
@@ -1,10 +1,10 @@
1
1
  module TonClient
2
-
2
+
3
3
  class Client
4
4
  include CommonInstanceHelpers
5
5
 
6
6
  attr_reader :core, :context
7
- private_accessor :_crypto, :_abi, :_boc, :_net, :_processing, :_tvm, :_utils
7
+ private_accessor :_crypto, :_abi, :_boc, :_processing, :_utils, :_tvm, :_net, :_debot
8
8
  MODULE = self.to_s.downcase.gsub(/^(.+::|)(\w+)$/, '\2').freeze
9
9
 
10
10
  def initialize(context: Context.new, core: TonClient::TonBinding)
@@ -12,22 +12,6 @@ module TonClient
12
12
  @core = core
13
13
  end
14
14
 
15
- def version(&block)
16
- core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
17
- end
18
-
19
- def get_api_reference(&block)
20
- core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
21
- end
22
-
23
- def build_info(&block)
24
- core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
25
- end
26
-
27
- def resolve_app_request(&block)
28
- core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
29
- end
30
-
31
15
  def destroy_context
32
16
  core.tc_destroy_context(context.id)
33
17
  end
@@ -44,20 +28,52 @@ module TonClient
44
28
  _boc ||= Boc.new(context: context)
45
29
  end
46
30
 
47
- def net
48
- _net ||= Net.new(context: context)
49
- end
50
-
51
31
  def processing
52
32
  _processing ||= Processing.new(context: context)
53
33
  end
54
34
 
35
+ def utils
36
+ _utils ||= Utils.new(context: context)
37
+ end
38
+
55
39
  def tvm
56
40
  _tvm ||= Tvm.new(context: context)
57
41
  end
58
42
 
59
- def utils
60
- _utils ||= Utils.new(context: context)
43
+ def net
44
+ _net ||= Net.new(context: context)
45
+ end
46
+
47
+ def debot
48
+ _debot ||= Debot.new(context: context)
49
+ end
50
+
51
+ # RESPONSE: ResultOfGetApiReference
52
+ # api: Value -
53
+ def get_api_reference(&block)
54
+ core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
61
55
  end
56
+
57
+ # RESPONSE: ResultOfVersion
58
+ # version: String - # # Core Library version
59
+ def version(&block)
60
+ core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
61
+ end
62
+
63
+ # RESPONSE: ResultOfBuildInfo
64
+ # build_number: Number - # # Build number assigned to this build by the CI.
65
+ # dependencies: Array - # # Fingerprint of the most important dependencies.
66
+ def build_info(&block)
67
+ core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: {}, &block)
68
+ end
69
+
70
+ # INPUT: ParamsOfResolveAppRequest
71
+ # app_request_id: Number - # # Request ID received from SDK
72
+ # result: AppRequestResult - # # Result of request processing
73
+ def resolve_app_request(payload, &block)
74
+ core.requestLibrary(context: context.id, method_name: full_method_name(MODULE, __method__.to_s), payload: payload, &block)
75
+ end
76
+
62
77
  end
63
- end
78
+ end
79
+
@@ -8,6 +8,7 @@ module TonClient
8
8
  @config = TonBinding.make_string(config.to_json)
9
9
  context = TonBinding.tc_create_context(@config)
10
10
  @id = TonBinding.read_string_to_hash(context)['result']
11
+ ObjectSpace.define_finalizer(self, self.class.finalize(@id))
11
12
  end
12
13
 
13
14
  def config=(value = {})
@@ -22,8 +23,12 @@ module TonClient
22
23
  TonBinding.tc_destroy_context(id)
23
24
  end
24
25
 
25
- def self.finalize
26
- TonBinding.tc_destroy_context(id)
26
+ def self.finalize(id)
27
+ Proc.new do
28
+ if (id != nil) && (id > 0)
29
+ TonBinding.tc_destroy_context(id)
30
+ end
31
+ end
27
32
  end
28
33
  end
29
34
  end