Methods
changeLanguage
To modify the widget's properties such as language and currency
Parameters
attributes
<WidgetAttributes>
defaultLanguage <String> Set the default language of the widget. The default value is
ko
, and currently supported languages areen
andko.
defaultCurrency
<String>
Set the default currency of the widget. The default value isKRW
, and currently supported currencies areUSD
andKRW.
Returns
None
Exception
Example
getStatus
Returns the lifecycle status of the WepinSDK.
Parameters
None
Returns
<WepinLifeCycle>
NOT_INITIALIZED - WepinSDK has not been initialized.
INITIALIZING - WepinSDK is in the process of initializing.
INITIALIZED - WepinSDK has been successfully initialized.
BEFORE_LOGIN - WepinSDK is initialized, but the user is not logged in.
LOGIN - The user is logged in and registered with Wepin.
LOGIN_BEFORE_REGISTER - The user is logged in but not registered with Wepin.
Exception
Example
login
The login
variable is a Wepin login library that includes various authentication methods, allowing users to log in using different approaches. It supports email and password login, OAuth provider login, login using ID tokens or access tokens, and more. For detailed information on each method, refer to the official Login Library guide.
Available Methods
These methods support various login scenarios, allowing you to select the appropriate method based on your needs
Exception
Example
loginWithUI
Supported from version `0.0.3 and later.
The loginWithUI
method provides the functionality to log in using a widget and returns the information of the logged-in user. If a user is already logged in, the widget will not be displayed, and the method will directely return the logged-in user's information. To perform a login without the widget, use the loginWepin() method from the login variable instead.
This method can only be used after the authentication key has been deleted from the Wepin Workspace(Wepin Workspace > Developer Tools menu > Login tab > Auth Key > Delete). The Auth Key menu is visible only if an authentication key was previously generated.
Parameters
LoginWithUIParameter
loginProviders
<Array>
An array of login providers to configure the widget. If an empty array is provided, only the email login function is available.
provider
<String>
The OAuth login provider (e.g., 'google', 'discord', 'naver', 'apple').clientId
<String>
The client ID of the OAuth login provider.
Returns
<WepinUser> (optional)
status
<'success' | 'fail'>
The login statususerInfo
<UserInfo>
(optional) The user's information, including:userId
<String>
The user's IDemail
<String>
The user's emailprovider
<'google'|'naver'|'discord'|'apple'|'email' | 'external_token'>
The login provideruse2FA
<Boolean>
Whether the user uses two-factor authentication
walletId
<String>
The user's wallet IDuserStatus
<UserStatus>
(optional) The user's Wepin login status, including:loginStatus
<WepinLoginStatus - 'complete' | 'pinRequired' | 'registerRequired'>
If the user'sloginStatus
value is not 'complete', the user must register with Wepin.pinRequired
<Boolean>
Whether a PIN is required
token
<Token>
The user's Wepin tokenaccessToken
<String>
The access tokenrefreshToken
<String>
The refresh token
Exception
Example
openWidget
Opens the widget window. If the user is not logged in, the widget window will not open. Therefore, the user must be logged in to Wepin before calling openWidget
. To log in to Wepin, use the loginWepin
method from the login
variable.
Parameters
None
Returns
None
Exception
Example
closeWidget
Closes the widget window. Closing the window does not log out the user.
Parameters
None
Returns
None
Exception
Example
register
Registers the user with Wepin. After signing up and logging in, the Wepin widget’s registration page opens, allowing the user to register (create a wallet and account) with Wepin services. This function can only be used when WepinLifeCycle
is loginBeforeRegister
. After calling the loginWepin()
method from the login
variable, if the loginStatus
value in userStatus
is not 'complete', this method should be called
Parameters
None
Returns
<WepinUser>
status
<'success' | 'fail'>
The login statususerInfo
<UserInfo>
(optional) The user's information, including:userId
<String>
The user's IDemail
<String>
The user's emailprovider
<'google' | 'apple' | 'naver' | 'discord' | 'email' | 'external_token'>
The login provideruse2FA
<Boolean>
Whether the user uses two-factor authentication
walletId
<String>
The user's wallet IDuserStatus
<UserStatus>
(optional) The user's Wepin login status, including:loginStatus
<WepinLoginStatus - 'complete' | 'pinRequired' | 'registerRequired'>
If the user'sloginStatus
value is not 'complete', the user must register with Wepin.pinRequired
<Boolean>
Whether a PIN is required
token
<Token>
The user's Wepin tokenaccessToken
<String>
The access tokenrefreshToken
<String>
The refresh token
Exception
Example
getAccounts
Returns the user's account information (networks and addresses) available in the app. This function can only be used after logging in to Wepin. If no parameters are provided, it returns information for all the user's accounts.
Parameters
networks
<List<String>>
optional The networks for which you want to return account information. The supported blockchain networks can be found on the supported blockchain pagewithEoa
<Boolean>
optional If AA accounts are present, this determines whether to include EOA accounts in the return.
Returns
<ArrayList<Account>> optional
network
<String>
The network type of the user's accountaddress
<String>
User account addresscontract
<String>
optional The contract address of the tokenisAA
<Boolean>
optional Indicates if it is an AA account
Exception
Example
getBalance
Returns the balance information (amount) of accounts. This function can only be used after logging in to Wepin. If no accounts
parameter is provided, it returns the balance of all user accounts.
Parameters
accounts
<ArrayList<Account>>
network
<String>
The network type of the account for which to check the balanceaddress
<String>
The address of the account for which to check the balancecontract
<String>
optional The contract address of the tokenisAA
<Boolean>
optional Indicates if it is an AA account
Returns
<ArrayList<AccountBalanceInfo>>
address
<String>
The network type of the user's accountnetwork
<String>
The address of the user's accountsymbol
<String>
Network symbolbalance
<String>
The amount of the network coin heldtokens
<TokenBalanceInfo>
symbol
<String>
Token symbolbalance
<String>
The amount of the token heldcontract
<String>
Token contract address
Exception
Example
getNFTs
Returns the user's NFTs. This function can only be used after logging in to Wepin. If no networks
parameter is provided, it returns all of the user's NFT information.
Parameters
refresh
<Boolean>
optional Required parameter to indicate whether to refresh the NFT datanetworks
<List<String>>
A list of network names to filter the NFTs
Returns
<ArrayList<WepinNFT>>
account
<Account>
network
<String>
The network type of the account for which to check the balanceaddress
<String>
The address of the account for which to check the balancecontract
<String>
optional The contract address of the tokenisAA
<Boolean>
optional Indicates if it is an AA account
contract
<WepinNFTContract>
name
<String>
NFT contract nameaddress
<String>
NFT contract addressscheme
<String>
Scheme of the NFTdescription
<String>
optional Description of the NFT contractnetwork
<String>
Network associated with the NFT contractexternalLink
<String>
optional External link associated with the NFT contractimageUrl
<String>
optional Image URL associated with the NFT contract
name
<String>
Name of the NFTdescription
<String>
Description of the NFTexternalLink
<String>
External link associated with the NFTimageUrl
<String>
Image URL associated with the NFTcontentUrl
<String>
optional URL pointing to the content associated with the NFTquantity
<Int>
Quantity of the NFTcontentType
<String>
Content type of the NFT ('image' | 'video')state
<Int>
State of the NFT
Exception
Example
send
Performs the send function using the widget and returns the ID information of the send transaction. This function can only be used after logging in to Wepin.
Parameters
sendData
<SendData>
account
<Account>
The user's account information to send fromnetwork
<String>
The network type of the account for which to check the balanceaddress
<String>
The address of the account for which to check the balancecontract
<String>
optional The contract address of the tokenisAA
<Boolean>
optional Indicates if it is an AA account
txData
<TxData>
toAddress
<String>
The address to send toamount
<String>
The amount to send
Returns
<SendResponse>
txId
<String>
The transaction ID of the send transaction
Exception
Example
receive
Supported from version `0.0.3 and later.
The receive
method opens the receive page associated with the specified account. This method can only be used after logging into Wepin.
Parameters
<Account> Provides the account information for the page that will be opend.
network
<String>
The network associated with the account.address
<String>
The address of the account.contract
<String>
optional The contract address of the token.
Returns
<ReceiveResponse> response containing the Account Info.
account
network
<String>
The network associated with the account.address
<String>
The address of the account.contract
<String>
optional The contract address of the token
Exception
Example
viewAccountDetail
Supported from version `0.0.4 and later.
The viewAccountDetail
method opens the account information page associated with the specified account. This method can only be used after logging into Wepin.
Parameters
<Account> Provides the account information for the page that will be opend.
network
<String>
The network associated with the account.address
<String>
The address of the account.contract
<String>
optional The contract address of the token.
Returns
<AccountDetailResponse> response containing the Account Info.
account
network
<String>
The network associated with the account.address
<String>
The address of the account.contract
<String>
optional The contract address of the token
Exception
Example
verifyPin
Supported from version `0.0.3 and later.
The verifyPin
method displays a screen where the user can input their PIN and verifies whether the entered PIN is correct.
Parameters
None
Returns
<Boolean>
true
is correct Pin
Exception
Example
finalize
Terminates the use of WepinSDK. The WepinLifeCycle
changes to notInitialized
.
Parameters
None
Returns
None
Exception
Example
WepinError
invalidAppKey
"InvalidAppKey"
The Wepin app key is invalid.
invalidParameters
`
"InvalidParameters"
One or more parameters provided are invalid or missing.
invalidLoginProvider
"InvalidLoginProvider"
The login provider specified is not supported or is invalid.
invalidToken
"InvalidToken"
The token does not exist.
invalidLoginSession
"InvalidLoginSession"
The login session information does not exist.
notInitialized
"NotInitialized"
The WepinLoginLibrary has not been properly initialized.
alreadyInitialized
"AlreadyInitialized"
The WepinLoginLibrary is already initialized, so the logout operation cannot be performed again.
userCancelled
"UserCancelled"
The user has cancelled the operation.
unknownError
"UnknownError"
An unknown error has occurred, and the cause is not identified.
notConnectedInternet
"NotConnectedInternet"
The system is unable to detect an active internet connection.
failedLogin
"FailedLogin"
The login attempt has failed due to incorrect credentials or other issues.
alreadyLogout
"AlreadyLogout"
The user is already logged out, so the logout operation cannot be performed again.
invalidEmailDomain
"InvalidEmailDomain"
The provided email address's domain is not allowed or recognized by the system.
failedSendEmail
"FailedSendEmail"
The system encountered an error while sending an email. This is because the email address is invalid or we sent verification emails too often. Please change your email or try again after 1 minute.
requiredEmailVerified
"RequiredEmailVerified"
Email verification is required to proceed with the requested operation.
incorrectEmailForm
"incorrectEmailForm"
The provided email address does not match the expected format.
incorrectPasswordForm
"IncorrectPasswordForm"
The provided password does not meet the required format or criteria.
notInitializedNetwork
"NotInitializedNetwork"
The network or connection required for the operation has not been properly initialized.
requiredSignupEmail
"RequiredSignupEmail"
The user needs to sign up with an email address to proceed.
failedEmailVerified
"FailedEmailVerified"
The WepinLoginLibrary encountered an issue while attempting to verify the provided email address.
failedPasswordStateSetting
"FailedPasswordStateSetting"
Failed to set the password state. This error may occur during password management operations, potentially due to invalid input or system issues.
failedPasswordSetting
"failedPasswordSetting"
Failed to set the password. This could be due to issues with the provided password or internal errors during the password setting process.
existedEmail
"ExistedEmail"
The provided email address is already registered. This error occurs when attempting to sign up with an email that is already in use.
apiRequestError
"ApiRequestError"
There was an error while making the API request. This can happen due to network issues, invalid endpoints, or server errors.
incorrectLifecycleException
"IncorrectLifecycleException"
The lifecycle of the Wepin SDK is incorrect for the requested operation. Ensure that the SDK is in the correct state (e.g., initialized
and login
) before proceeding.
failedRegister
"FailedRegister"
Failed to register the user. This can occur due to issues with the provided registration details or internal errors during the registration process.
accountNotFound
"AccountNotFound"
The specified account was not found. This error is returned when attempting to access an account that does not exist in the Wepin.
nftNotFound
"NftNotFound"
The specified NFT was not found. This error occurs when the requested NFT does not exist or is not accessible within the user's account.
failedSend
"FailedSend"
Failed to send the required data or request. This error could be due to network issues, incorrect data, or internal server errors.
failedReceive
"FailedReceive"
Failed to open the receive page. This error could be due to network issues, incorrect data, or internal server errors.
failedAppDetail
"FailedViewAccountDetail"
Failed to open the account detail page. This error could be due to network issues, incorrect data, or internal server errors.
failedPinVerified
"FailedToVerifyPin"
Failed to verify pin. This error could be due to network issues, incorrect data, or internal server errors.
Last updated