Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: eth_signTransaction and personal_sign components #125

Merged
merged 25 commits into from
May 23, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
1fd330e
feat: added support for eth_signTransaction and personal_sign
JeneaVranceanu Aug 23, 2023
bf95be7
chore: disabled vetur.validation.script as it triggered incorrect err…
JeneaVranceanu Aug 23, 2023
bd9a3dd
chore: extracted method selectors in a separate file to reuse across …
JeneaVranceanu Aug 23, 2023
d52d2c9
chore: updated `permissions: Permissions` in Permissions.vue file to …
JeneaVranceanu Aug 23, 2023
aac7047
fix: changed wrong title and docs links in personal_sign component
JeneaVranceanu Aug 23, 2023
9be150e
chore: dropped arbitraryRpc function
JeneaVranceanu Aug 23, 2023
564d8d5
Merge branch 'main' into feat/sign-components
JeneaVranceanu Aug 23, 2023
a0cb311
fix: removed unused imports - the cause for Lint failure
JeneaVranceanu Aug 24, 2023
c5f6ab7
fix: wrong fields in Permissions object
JeneaVranceanu Aug 24, 2023
f4ffe1c
fix: PersonalSign tests + passing password to personal_sign
JeneaVranceanu Aug 29, 2023
6e7ec07
fix: tests for SignTransaction
JeneaVranceanu Aug 29, 2023
73fa14a
fix: linter errors
JeneaVranceanu Aug 29, 2023
df83fd3
chore: merged with main
JeneaVranceanu Sep 4, 2023
56c748f
fix: failing tests
JeneaVranceanu Sep 4, 2023
708e67d
chore: do not show eth_signTransaction component
JeneaVranceanu Nov 26, 2023
2ced718
chore: removed unused import
JeneaVranceanu Nov 26, 2023
a57c125
chore: merged with main
JeneaVranceanu Apr 17, 2024
5709d24
chore: lint fix
JeneaVranceanu Apr 17, 2024
f71122b
chore: uncommented eth_signTransaction even though it's not supported…
JeneaVranceanu Apr 17, 2024
297443d
chore: gas to number from string
JeneaVranceanu Apr 17, 2024
4986616
chore: gas to Number.MAX_VALUE
JeneaVranceanu Apr 17, 2024
e25a9d5
chore: logging transaction hash
JeneaVranceanu May 16, 2024
9b7aff6
Merge branch 'main' into feat/sign-components
JeneaVranceanu May 17, 2024
7163dd2
fix: old tests failing
JeneaVranceanu May 17, 2024
e2e9fd5
chore: combined eth_sign and personal_sign components
JeneaVranceanu May 17, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions public/visibility_off.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
4 changes: 4 additions & 0 deletions public/visibility_on.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
30 changes: 16 additions & 14 deletions src/components/endpoints/Permissions.vue
Original file line number Diff line number Diff line change
Expand Up @@ -23,27 +23,29 @@ const { encodePermissions, decodePermissions, getInstance } = useErc725()
const grantPermissionAddress = ref('0xaf3bf2ffb025098b79caddfbdd113b3681817744')
const permissions: Permissions = {
CHANGEOWNER: false,
EDITPERMISSIONS: false,
ADDCONTROLLER: false,
SETDATA: false,
CALL: false,
STATICCALL: false,
DELEGATECALL: false,
DEPLOY: false,
TRANSFERVALUE: false,
SIGN: false,
ENCRYPT: false,
SUPER_SETDATA: false,
SUPER_TRANSFERVALUE: false,
SUPER_CALL: false,
SUPER_STATICCALL: false,
SUPER_DELEGATECALL: false,
EDITPERMISSIONS: false,
ADDEXTENSIONS: false,
CHANGEEXTENSIONS: false,
ADDUNIVERSALRECEIVERDELEGATE: false,
CHANGEUNIVERSALRECEIVERDELEGATE: false,
REENTRANCY: false,
SUPER_TRANSFERVALUE: false,
TRANSFERVALUE: false,
SUPER_CALL: false,
CALL: false,
SUPER_STATICCALL: false,
STATICCALL: false,
SUPER_DELEGATECALL: false,
DELEGATECALL: false,
DEPLOY: false,
SUPER_SETDATA: false,
SETDATA: false,
ENCRYPT: false,
DECRYPT: false,
SIGN: false,
EXECUTE_RELAY_CALL: false,
ERC4337_PERMISSION: false,
}
const selectedPermissions = ref(permissions)
const isPending = ref(false)
Expand Down
280 changes: 2 additions & 278 deletions src/components/endpoints/SendTransaction.vue
Original file line number Diff line number Diff line change
Expand Up @@ -6,19 +6,17 @@ import { TransactionConfig } from 'web3-core'
import { getState, setState } from '@/stores'
import Notifications from '@/components/Notification.vue'
import useNotifications from '@/compositions/useNotifications'
import useWeb3Connection from '@/compositions/useWeb3Connection'
import {
DEFAULT_GAS,
DEFAULT_GAS_PRICE,
DEFAULT_MAX_FEE_PER_GAS,
DEFAULT_MAX_PRIORITY_FEE_PER_GAS,
getSelectedNetworkConfig,
} from '@/helpers/config'
import ContractFunction from '@/components/shared/ContractFunction.vue'
import { MethodSelect, MethodType } from '@/helpers/functionUtils'
import { LSPType } from '@/helpers/tokenUtils'
import useWeb3Connection from '@/compositions/useWeb3Connection'
import { methodSelectors as methods } from '@/utils/methodSelectors'

const { sampleUP, errorContract } = getSelectedNetworkConfig()
const { notification, clearNotification, hasNotification, setNotification } =
useNotifications()
const {
Expand All @@ -37,280 +35,6 @@ const resultFormat = reactive<{ item: MethodSelect }>({
item: { label: 'results' },
})

const methods: MethodSelect[] = [
JeneaVranceanu marked this conversation as resolved.
Show resolved Hide resolved
{
label: '💰 Default',
},
{
label: '💰 Transfer LSP7/LSP8',
call: 'transfer',
inputs: [
{ type: 'address', name: 'from' },
{ type: 'address', name: 'to' },
{ type: 'uint256', name: 'amount', value: '1', isWei: 'ether' },
{ type: 'bool', name: 'force', value: false },
{ type: 'bytes', name: 'data', value: '0x' },
],
hasSpecs: [LSPType.LSP7DigitalAsset, LSPType.LSP8IdentifiableDigitalAsset],
},
{
label: '💰 Authorize Operator LSP7',
call: 'authorizeOperator',
inputs: [
{ type: 'address', name: 'operator', value: sampleUP },
{ type: 'uint256', name: 'amount', value: '1' },
{ type: 'bytes', name: 'operatorNotificationData', value: '0x' },
],
hasSpecs: [LSPType.LSP7DigitalAsset],
},
{
label: '💰 Revoke Operator LSP7 v12',
call: 'revokeOperator',
inputs: [
{ type: 'address', name: 'operator', value: sampleUP },
{ type: 'bool', name: 'notify', value: true },
{ type: 'bytes', name: 'operatorNotificationData', value: '0x' },
],
hasSpecs: [LSPType.LSP7DigitalAsset],
},
{
label: '💰 Revoke Operator LSP7 v15',
call: 'revokeOperator',
inputs: [
{ type: 'address', name: 'operator', value: sampleUP },
{ type: 'address', name: 'tokenOwner', value: sampleUP },
{ type: 'bool', name: 'notify', value: true },
{ type: 'bytes', name: 'operatorNotificationData', value: '0x' },
],
hasSpecs: [LSPType.LSP7DigitalAsset],
},
{
label: '🏦 Mint LSP7',
call: 'mint',
inputs: [
{ type: 'address', name: 'to' },
{ type: 'uint256', name: 'amount', value: '1' },
{ type: 'bool', name: 'force', value: false },
{ type: 'bytes', name: 'data', value: '0x' },
],
hasSpecs: [LSPType.LSP7DigitalAsset],
},
{
label: '💰 Authorize Operator LSP8',
call: 'authorizeOperator',
inputs: [
{ type: 'address', name: 'operator', value: sampleUP },
{ type: 'bytes32', name: 'tokenId', value: '1' },
{ type: 'bytes', name: 'operatorNotificationData', value: '0x' },
],
hasSpecs: [LSPType.LSP8IdentifiableDigitalAsset],
},
{
label: '💰 Revoke Operator LSP8',
call: 'revokeOperator',
inputs: [
{ type: 'address', name: 'operator', value: sampleUP },
{ type: 'bytes32', name: 'tokenId', value: '1' },
{ type: 'bool', name: 'notify', value: true },
{ type: 'bytes', name: 'operatorNotificationData', value: '0x' },
],
hasSpecs: [LSPType.LSP8IdentifiableDigitalAsset],
},

{
label: '🏦 Mint LSP8',
call: 'mint',
inputs: [
{ type: 'address', name: 'to' },
{ type: 'bytes32', name: 'tokenId', value: '1' },
{ type: 'bool', name: 'force', value: false },
{ type: 'bytes', name: 'data', value: '0x' },
],
hasSpecs: [LSPType.LSP8IdentifiableDigitalAsset],
},
{
label: '💰 Transfer Ownership UP',
call: 'transferOwnership',
inputs: [{ type: 'address', name: 'newOwner' }],
hasSpecs: [LSPType.UP],
},
{
label: '💰 Accept Ownership UP',
call: 'acceptOwnership',
inputs: [],
hasSpecs: [LSPType.UP],
},
{
label: '💰 Renounce Ownership UP',
call: 'renounceOwnership',
inputs: [],
hasSpecs: [LSPType.UP],
},
{
label: '💰 Transfer ERC20/ERC777',
call: 'transfer',
inputs: [
{ type: 'address', name: 'to', value: sampleUP },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '1' },
],
hasSpecs: [LSPType.ERC20, LSPType.ERC777],
},
{
label: '💰 Send ERC777',
call: 'send',
hasSpecs: [LSPType.ERC777],
inputs: [
{ type: 'address', name: 'to' },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '1' },
{ type: 'bytes', name: 'data', value: '0x' },
],
},
{
label: '💰Operator Send ERC777',
call: 'operatorSend',
hasSpecs: [LSPType.ERC777],
inputs: [
{ type: 'address', name: 'sender' },
{ type: 'address', name: 'recipient' },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '1' },
{ type: 'bytes', name: 'data', value: '0x' },
{ type: 'bytes', name: 'operatorData', value: '0x' },
],
},
{
label: '💰Operator Burn ERC777',
call: 'operatorBurn',
hasSpecs: [LSPType.ERC777],
inputs: [
{ type: 'address', name: 'account' },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '1' },
{ type: 'bytes', name: 'data', value: '0x' },
{ type: 'bytes', name: 'operatorData', value: '0x' },
],
},
{
label: '💰 TransferFrom ERC721',
call: 'transferFrom',
inputs: [
{ type: 'address', name: 'from' },
{ type: 'address', name: 'to' },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '1' },
],
hasSpecs: [LSPType.ERC721],
},
{
label: '💰 Approve ERC721 / ERC20',
call: 'approve',
inputs: [
{ type: 'address', name: 'approved' },
{ type: 'uint256', name: 'tokenId', value: '1' },
],
hasSpecs: [LSPType.ERC721, LSPType.ERC20],
},
{
label: '💰 SafeTransferFrom ERC1155',
call: 'safeTransferFrom',
inputs: [
{ type: 'address', name: 'from' },
{ type: 'address', name: 'to' },
{ type: 'uint256', name: 'id' },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '1' },
{ type: 'bytes', name: 'data', value: '0x' },
],
hasSpecs: [LSPType.Unknown],
},
{
label: '🏦 Mint ERC20/ERC777/LSP7',
call: 'mint',
hasSpecs: [LSPType.ERC777, LSPType.ERC20, LSPType.LSP7DigitalAsset],
inputs: [
{ type: 'address', name: 'to' },
{ type: 'uint256', name: 'amount', isWei: 'ether', value: '100' },
],
},
{
label: '🎛️ SetData',
call: 'setDataBatch',
hasSpecs: [
LSPType.UP,
LSPType.LSP3ProfileMetadata,
LSPType.LSP7DigitalAsset,
LSPType.LSP8IdentifiableDigitalAsset,
LSPType.LSP9Vault,
],
inputs: [
{
type: 'bytes32[]',
name: 'keys',
isPairs: true,
isKey: true,
},
{ type: 'bytes[]', name: 'values', isPairs: true },
],
},
{
label: '⛔️ Call revertWithCustomError',
call: 'revertWithCustomError',
inputs: [],
hasSpecs: [LSPType.ERROR_TEST],
to: errorContract,
amount: '0',
},
{
label: '⛔️ Call revertWithErrorString',
call: 'revertWithErrorString',
inputs: [],
hasSpecs: [LSPType.ERROR_TEST],
to: errorContract,
amount: '0',
},
{
label: '⛔️ Call revertWithPanicError',
call: 'revertWithPanicError',
inputs: [],
hasSpecs: [LSPType.ERROR_TEST],
to: errorContract,
amount: '0',
},
{
label: '⛔️ Call revertWithNoErrorData',
call: 'revertWithNoErrorData',
inputs: [],
hasSpecs: [LSPType.ERROR_TEST],
to: errorContract,
amount: '0',
},
{
label: '🦾 Sample call data',
call: 'init',
inputs: [
{
type: 'address[]',
name: 'addresses',
value: [
'0x69909C12C875271AdC49155Cc8D01dBF67FE82f1',
'0xB27F5845E6Ce846C02209Bd2497780099611b9a0',
],
},
{
type: 'bytes32',
name: 'data',
value:
'0x40b8bec57d7b5ff0dbd9e9acd0a47dfeb0101e1a203766f5ccab00445fbf39e9',
},
{ type: 'uint256[]', name: 'numbers', value: ['2345675643', '123292'] },
{ type: 'bool', name: 'force', value: true },
{ type: 'string', name: 'scream', value: 'Hello!' },
{
type: 'string',
name: 'description',
value:
'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.',
},
],
},
]

watch(
() => getState('address'),
newAddress => {
Expand Down
Loading