Links
Comment on page

Sign Message

Make sure you initialize Blocto SDK first
Once your app is connected to Blocto wallet, it can send sign EVMBase message on behalf of the user, with the user's permission.
Currently we support these sign types:
public enum EVMBaseSignType: String {
case sign // stand for eth_sign
case personalSign = "personal_sign"
case typedSignV3 = "typed_data_sign_v3"
case typedSignV4 = "typed_data_sign_v4"
case typedSign = "typed_data_sign" // same as the latest, it's same as default v4 for now.
}
When using sign type, please make sure input message is hex string with **0x**prefix.
We highly recommend you specify version when using typedSign. Because we can't make sure what version of Blocto Wallet app the user installed. When using **typedSign**we just use the latest version of typedSign, but the "latest" typedSign in user's current Blocto Wallet app might not match with the "latest" typedSign in BloctoSDK. In such case, it may lead to unexpected result.
Let's take Ethereum for example. Arbitrum, Optimism, BSC, Polygon and Avalanche use the same signMessage method as below.

Sign message

Sign

BloctoSDK.shared.evm.signMessage(
blockchain: .ethereum,
from: "0x...", // user address
message: "0x50...3A", // must be hex string with 0x prefix
signType: .sign) { [weak self] result in
guard let self = self else { return }
switch result {
case let .success(signature):
// handle signature here.
case let .failure(error):
// handle error here.
}
}

Personal sign

BloctoSDK.shared.evm.signMessage(
blockchain: .ethereum,
from: "0x...", // user address
message: "any message",
signType: .personalSign) { [weak self] result in
guard let self = self else { return }
switch result {
case let .success(signature):
// handle signature here.
case let .failure(error):
// handle error here.
}
}

Typed sign v3

BloctoSDK.shared.evm.signMessage(
blockchain: .ethereum,
from: "0x...", // user address
message: #"{ "abc": 123 }"#, // must be valid json format.
signType: .typedSignV3) { [weak self] result in
guard let self = self else { return }
switch result {
case let .success(signature):
// handle signature here.
case let .failure(error):
// handle error here.
}
}

Typed sign v4

BloctoSDK.shared.evm.signMessage(
blockchain: .ethereum,
from: "0x...", // user address
message: #"{ "abc": 123 }"#, // must be valid json format.
signType: .typedSignV4) { [weak self] result in
guard let self = self else { return }
switch result {
case let .success(signature):
// handle signature here.
case let .failure(error):
// handle error here.
}
}