Esempio n. 1
0
def register_owner_account(token: Token):
    if Wallet.objects.filter(token=token,
                             address=remove_0x_prefix(
                                 settings.HUB_OWNER_ACCOUNT_ADDRESS)).exists():
        return

    if not LocalViewInterface.get_contract_parameters():
        return

    latest_eon_number = LocalViewInterface.latest().eon_number()

    authorization_digest = Wallet(
        token=token,
        address=settings.HUB_OWNER_ACCOUNT_ADDRESS).get_admission_hash(
            latest_eon_number)
    authorization = sign_message(authorization_digest,
                                 settings.HUB_OWNER_ACCOUNT_KEY)
    latest_tos_config = TOSConfig.objects.all().order_by('time').last()
    tos_signature = sign_message(decode_hex(latest_tos_config.digest()),
                                 settings.HUB_OWNER_ACCOUNT_KEY)

    registration = AdmissionRequestSerializer(
        data={
            'token': token.address,
            'address': remove_0x_prefix(settings.HUB_OWNER_ACCOUNT_ADDRESS),
            'authorization': {
                'value': encode_signature(authorization)
            },
            'tos_signature': {
                'value': encode_signature(tos_signature)
            }
        })
    registration.is_valid(raise_exception=True)
    registration.save()
Esempio n. 2
0
def register_owner_account(token: Token):
    if Wallet.objects.filter(token=token, address__iexact=remove_0x_prefix(settings.HUB_OWNER_ACCOUNT_ADDRESS)).exists():
        logger.error('Owner account already registered.')
        return

    if not LocalViewInterface.get_contract_parameters():
        logger.error('Contract parameters not yet populated.')
        return

    logger.warning('Registering owner account: {}'.format(
        settings.HUB_OWNER_ACCOUNT_ADDRESS))

    latest_eon_number = LocalViewInterface.latest().eon_number()

    authorization_digest = Wallet(
        token=token, address=settings.HUB_OWNER_ACCOUNT_ADDRESS).get_admission_hash(latest_eon_number)
    authorization = sign_message(
        authorization_digest, settings.HUB_OWNER_ACCOUNT_KEY)
    latest_tos_config = TOSConfig.objects.all().order_by('time').last()
    tos_signature = sign_message(
        hex_value(latest_tos_config.digest()), settings.HUB_OWNER_ACCOUNT_KEY)
    registration = AdmissionRequestSerializer(data={
        'token': token.address,
        'address': remove_0x_prefix(settings.HUB_OWNER_ACCOUNT_ADDRESS),
        'authorization': {
            'value': encode_signature(authorization)
        },
        'tos_signature': {
            'value': encode_signature(tos_signature)
        }
    })
    registration.is_valid(raise_exception=True)
    registration.save()
    process_admissions()
Esempio n. 3
0
    def test_wallet_funds(self):
        hub_mba = MinimumAvailableBalanceMarker(wallet=self.hub_wallet,
                                                amount=1,
                                                eon_number=3)

        mba_checksum = hub_mba.checksum()

        sign = Signature(wallet=self.hub_wallet,
                         checksum=crypto.hex_value(mba_checksum),
                         value=crypto.encode_signature(
                             crypto.sign_message(
                                 mba_checksum, self.hub_private.to_string())))

        sign.save()
        hub_mba.signature = sign
        hub_mba.save()

        hub_state = ActiveState(wallet=self.hub_wallet,
                                eon_number=3,
                                updated_spendings=4,
                                updated_gains=76,
                                tx_set_hash=uuid.uuid4().hex,
                                tx_set_index=2)

        state_checksum = hub_state.checksum()
        sign = Signature(
            wallet=self.hub_wallet,
            checksum=crypto.hex_value(state_checksum),
            value=crypto.encode_signature(
                crypto.sign_message(state_checksum,
                                    self.hub_private.to_string())))
        sign.save()
        hub_state.wallet_signature = sign
        hub_state.save()

        transfer = Transfer(
            wallet=self.hub_wallet,
            sender_balance_marker=hub_mba,
            amount=100000,
            eon_number=NOCUSTContractInterface().get_current_eon_number(),
            recipient=self.wallet,
            nonce=random.randint(1, 1000),
            sender_active_state=hub_state,
            passive=True)
        transfer.save()

        response = self.client.post(self.url, data=self.payload).json()
        self.assertEqual(response, "Ok")
Esempio n. 4
0
def freeze_swap(test_case: RPCTestCase,
                swap: Transfer,
                account,
                expected_status=status.HTTP_200_OK):
    freeze_authorization = sign_message(
        swap.swap_cancellation_message_checksum(), account.get('pk'))
    # Make API Request
    url = reverse('freeze-swap-endpoint', kwargs={'pk': swap.id})
    data = {
        'freezing_signature': {
            'value': encode_signature(freeze_authorization)
        }
    }

    # Send tx to server
    x = datetime.now()
    response = test_case.client.put(url, data, format='json')
    y = datetime.now()
    delta = y - x

    # Ensure the transaction was recorded
    test_case.assertEqual(response.status_code, expected_status,
                          response.content)

    print('FREEZE Time: {}s'.format(delta))

    # Log time delta
    return delta
Esempio n. 5
0
def register_account(test_case: RPCTestCase, token, address, authorization,
                     tos_signature):
    # Create a request
    url = reverse('admission-endpoint')
    data = {
        'token': remove_0x_prefix(token),
        'address': remove_0x_prefix(address),
        'authorization': {
            'value': encode_signature(authorization)
        },
        'tos_signature': {
            'value': encode_signature(tos_signature)
        }
    }
    response = test_case.client.post(url, data, format='json')

    test_case.assertEqual(response.status_code, status.HTTP_201_CREATED)
Esempio n. 6
0
def register_bulk_accounts(test_case: RPCTestCase, accounts):
    # Create a request
    url = reverse('bulk-admission-endpoint')
    data = {'admissions': []}
    for i in range(len(accounts)):
        data['admissions'].append({
            'token':
            remove_0x_prefix(accounts[i]['token']),
            'address':
            remove_0x_prefix(accounts[i]['address']),
            'authorization': {
                'value': encode_signature(accounts[i]['authorization'])
            },
            'tos_signature': {
                'value': encode_signature(accounts[i]['tos_signature'])
            }
        })

    response = test_case.client.post(url, data, format='json')
    test_case.assertEqual(response.status_code, status.HTTP_201_CREATED)
Esempio n. 7
0
    def sign_admission(self, eon_number, operator_wallet, private_key):
        admission_hash = self.get_admission_hash(eon_number)
        admission_hash_encoded = hex_value(admission_hash)

        vrs = sign_message(m=admission_hash, k=private_key)

        Signature = apps.get_model('ledger', 'Signature')
        operator_signature = Signature.objects.create(
            wallet=operator_wallet,
            checksum=admission_hash_encoded,
            value=encode_signature(vrs))

        return operator_signature
Esempio n. 8
0
    def sign_active_state(self, address, private_key):
        raw_checksum = self.checksum()
        vrs = sign_message(m=raw_checksum, k=private_key)

        Wallet = apps.get_model('ledger', 'Wallet')
        try:
            operator_wallet = Wallet.objects.get(
                token=self.wallet.token, address=remove_0x_prefix(address))
        except Wallet.DoesNotExist:
            raise LookupError(
                'Signing wallet {} is not yet registered'.format(address))

        Signature = apps.get_model('ledger', 'Signature')
        operator_signature = Signature.objects.create(
            wallet=operator_wallet,
            checksum=hex_value(raw_checksum),
            value=encode_signature(vrs))

        return operator_signature
Esempio n. 9
0
def register_sla_recipient_account():
    if same_hex_value(settings.SLA_RECIPIENT_ADDRESS,
                      settings.HUB_OWNER_ACCOUNT_ADDRESS):
        logger.warning('Skipping registration: Hub Owner is SLA recipient.')
        return

    token = Token.objects.filter(
        address__iexact=remove_0x_prefix(settings.SLA_TOKEN_ADDRESS))

    if not token.exists():
        logger.error('SLA Payment Token not yet registered.')
        return

    if Wallet.objects.filter(token=token,
                             address__iexact=remove_0x_prefix(
                                 settings.SLA_RECIPIENT_ADDRESS)).exists():
        logger.error('Recipient account already registered.')
        return

    if not LocalViewInterface.get_contract_parameters():
        logger.error('Contract parameters not yet populated.')
        return

    latest_eon = LocalViewInterface.latest().eon_number()

    authorization_digest = Wallet(
        token=token,
        address=settings.SLA_RECIPIENT_ADDRESS).get_admission_hash(latest_eon)
    authorization = sign_message(authorization_digest,
                                 settings.SLA_RECIPIENT_KEY)
    registration = AdmissionRequestSerializer(
        data={
            'token': token.address,
            'address': remove_0x_prefix(settings.SLA_RECIPIENT_ADDRESS),
            'authorization': encode_signature(authorization)
        })
    registration.is_valid(raise_exception=True)
    registration.save()
    process_admissions()
Esempio n. 10
0
    def setUp(self):
        super().setUp()
        message = [
            crypto.address(self.wallet.address),  # wallet
            crypto.address(self.eth_token.address),  # token
            crypto.uint256(10000),  # amount
            crypto.uint256(57)  # expiry
        ]
        message = crypto.hash_array(message)
        signature = crypto.encode_signature(
            crypto.sign_message(message, self.private.to_string()))
        self.right_sig = signature
        self.url = reverse("delegated-withdrawal-endpoint")

        self.update_registration(signature, message)
        self.payload = {
            "signature": self.right_sig,
            "wallet": self.wallet,
            "token": self.eth_token.address,
            "amount": 10000,
            "expiry": 57
        }
Esempio n. 11
0
def cancel_swap(test_case: RPCTestCase,
                swap: Transfer,
                account,
                expected_status=status.HTTP_200_OK,
                eon_count=1):
    sender_cancellation_authorizations = []
    recipient_cancellation_authorizations = []

    sender_view_context = WalletTransferContext(wallet=swap.wallet,
                                                transfer=swap)

    tx_set_tree = sender_view_context.authorized_transfers_tree(
        only_appended=False,
        force_append=False,
        assume_active_state_exists=True)
    tx_set_hash = crypto.hex_value(tx_set_tree.root_hash())
    transfer_index = tx_set_tree.merkle_tree_nonce_map.get(swap.nonce)
    transfer_proof = tx_set_tree.proof(transfer_index)

    sender_highest_spendings, sender_highest_gains = sender_view_context.off_chain_actively_sent_received_amounts(
        eon_number=swap.eon_number, only_appended=False)

    matched_out, _ = swap.matched_amounts()

    sender_highest_gains += swap.amount - matched_out

    sender_cancellation_active_state = ActiveState(
        wallet=swap.wallet,
        updated_spendings=sender_highest_spendings,
        updated_gains=sender_highest_gains,
        tx_set_hash=tx_set_hash,
        tx_set_proof_hashes=transfer_proof,
        tx_set_index=transfer_index,
        eon_number=swap.eon_number)

    recipient_view_context = WalletTransferContext(wallet=swap.recipient,
                                                   transfer=swap)

    tx_set_tree = recipient_view_context.authorized_transfers_tree(
        only_appended=False,
        force_append=False,
        assume_active_state_exists=True)
    tx_set_hash = crypto.hex_value(tx_set_tree.root_hash())
    transfer_index = tx_set_tree.merkle_tree_nonce_map.get(swap.nonce)
    transfer_proof = tx_set_tree.proof(transfer_index)

    recipient_highest_spendings, recipient_highest_gains = recipient_view_context.off_chain_actively_sent_received_amounts(
        eon_number=swap.eon_number, only_appended=False)

    recipient_cancellation_active_state = ActiveState(
        wallet=swap.recipient,
        updated_spendings=recipient_highest_spendings + swap.amount_swapped,
        updated_gains=recipient_highest_gains + swap.amount_swapped,
        tx_set_hash=tx_set_hash,
        tx_set_proof_hashes=transfer_proof,
        tx_set_index=transfer_index,
        eon_number=swap.eon_number)

    sender_cancellation_authorizations.append({
        'value':
        encode_signature(
            sign_message(sender_cancellation_active_state.checksum(),
                         account.get('pk')))
    })
    recipient_cancellation_authorizations.append({
        'value':
        encode_signature(
            sign_message(recipient_cancellation_active_state.checksum(),
                         account.get('pk')))
    })

    for i in range(1, eon_count):
        empty_tx_set_hash = crypto.hex_value(NODE_CACHE[0]['hash'])
        sender_future_spent_gained = max(sender_highest_spendings,
                                         sender_highest_gains) + 1
        recipient_future_spent_gained = max(
            recipient_highest_spendings,
            recipient_highest_gains) + swap.amount_swapped + 1

        sender_cancellation_active_state = ActiveState(
            wallet=swap.wallet,
            updated_spendings=sender_future_spent_gained,
            updated_gains=sender_future_spent_gained,
            tx_set_hash=empty_tx_set_hash,
            # any dummy value
            tx_set_proof_hashes='',
            # any dummy value
            tx_set_index=0,
            eon_number=swap.eon_number + i)

        recipient_cancellation_active_state = ActiveState(
            wallet=swap.recipient,
            updated_spendings=recipient_future_spent_gained,
            updated_gains=recipient_future_spent_gained,
            tx_set_hash=empty_tx_set_hash,
            # any dummy value
            tx_set_proof_hashes='',
            # any dummy value
            tx_set_index=0,
            eon_number=swap.eon_number + i)

        sender_cancellation_authorizations.append({
            'value':
            encode_signature(
                sign_message(sender_cancellation_active_state.checksum(),
                             account.get('pk')))
        })
        recipient_cancellation_authorizations.append({
            'value':
            encode_signature(
                sign_message(recipient_cancellation_active_state.checksum(),
                             account.get('pk')))
        })

    # Make API Request
    url = reverse('cancel-swap-endpoint', kwargs={'pk': swap.id})
    data = {
        'sender_cancellation_signature': sender_cancellation_authorizations,
        'recipient_cancellation_signature':
        recipient_cancellation_authorizations
    }

    # Send tx to server
    x = datetime.now()
    response = test_case.client.put(url, data, format='json')
    y = datetime.now()
    delta = y - x

    # Ensure the transaction was recorded
    test_case.assertEqual(response.status_code, expected_status,
                          response.content)

    print('CANCEL Time: {}s'.format(delta))

    # Log time delta
    return delta
Esempio n. 12
0
def finalize_swap(test_case: RPCTestCase,
                  swap: Transfer,
                  account,
                  expected_status=status.HTTP_200_OK,
                  eon_count=1):
    print('FINALIZING {} ({}/{})'.format(swap.id, int(swap.amount),
                                         int(swap.amount_swapped)))

    finalization_authorizations = []
    test_case.assertTrue(swap.complete)

    recipient_view_context = WalletTransferContext(wallet=swap.recipient,
                                                   transfer=swap)

    tx_set_tree = recipient_view_context.authorized_transfers_tree(
        only_appended=False, force_append=True)
    tx_set_hash = crypto.hex_value(tx_set_tree.root_hash())
    transfer_index = tx_set_tree.merkle_tree_nonce_map.get(swap.nonce)
    transfer_proof = tx_set_tree.proof(transfer_index)

    highest_spendings, highest_gains = recipient_view_context.off_chain_actively_sent_received_amounts(
        eon_number=swap.eon_number, only_appended=False)

    print("Finalize spent {} gained {}".format(highest_spendings,
                                               highest_gains))

    for state in ActiveState.objects.filter(wallet=swap.recipient,
                                            eon_number=swap.eon_number):
        print(state.id)
        print("Finalize spent {} gained {}".format(state.updated_spendings,
                                                   state.updated_gains))

    finalization_active_state = ActiveState(
        wallet=swap.recipient,
        updated_spendings=highest_spendings + swap.amount_swapped,
        updated_gains=highest_gains + swap.amount_swapped,
        tx_set_hash=tx_set_hash,
        tx_set_proof_hashes=transfer_proof,
        tx_set_index=transfer_index,
        eon_number=swap.eon_number)

    finalization_authorizations.append({
        'value':
        encode_signature(
            sign_message(finalization_active_state.checksum(),
                         account.get('pk')))
    })

    for i in range(1, eon_count):
        future_spent_gained = max(highest_spendings,
                                  highest_gains) + swap.amount_swapped + 1
        empty_tx_set_hash = crypto.hex_value(NODE_CACHE[0]['hash'])
        finalization_active_state = ActiveState(
            wallet=swap.recipient,
            updated_spendings=future_spent_gained,
            updated_gains=future_spent_gained,
            tx_set_hash=empty_tx_set_hash,
            # any dummy value
            tx_set_proof_hashes='',
            # any dummy value
            tx_set_index=0,
            eon_number=swap.eon_number + i)

        finalization_authorizations.append({
            'value':
            encode_signature(
                sign_message(finalization_active_state.checksum(),
                             account.get('pk')))
        })

    # Make API Request
    url = reverse('finalize-swap-endpoint', kwargs={'pk': swap.id})
    data = {'finalization_signature': finalization_authorizations}

    # Send tx to server
    x = datetime.now()
    response = test_case.client.put(url, data, format='json')
    y = datetime.now()
    delta = y - x

    # Ensure the transaction was recorded
    test_case.assertEqual(response.status_code, expected_status,
                          response.content)

    print('FINALIZE Time: {}s'.format(delta))

    # Log time delta
    return delta
Esempio n. 13
0
def send_swap(test_case: RPCTestCase,
              eon_number,
              account,
              token,
              token_swapped,
              amount,
              amount_swapped,
              nonce,
              expected_status=status.HTTP_201_CREATED,
              eon_count=1,
              sell_order=True):
    # Sender account
    sender_wallet = Wallet.objects.get(address=remove_0x_prefix(
        account.get('address')),
                                       token=token)
    # Recipient account
    recipient_wallet = Wallet.objects.get(address=remove_0x_prefix(
        account.get('address')),
                                          token=token_swapped)

    sender_wallet_context = WalletTransferContext(wallet=sender_wallet,
                                                  transfer=None)
    recipient_wallet_context = WalletTransferContext(wallet=recipient_wallet,
                                                     transfer=None)

    initial_sender_balance = sender_wallet_context.available_funds_at_eon(
        eon_number=eon_number, only_appended=False)
    initial_recipient_balance = recipient_wallet_context.available_funds_at_eon(
        eon_number=eon_number, only_appended=False)

    if initial_sender_balance < amount:
        send_transaction(test_case=test_case,
                         eon_number=eon_number,
                         sender=testrpc_accounts.accounts[0],
                         recipient=account,
                         amount=amount - initial_sender_balance,
                         nonce=random.randint(1, 999999),
                         token=token)
    if initial_sender_balance > amount:
        # clear sender account
        send_transaction(test_case=test_case,
                         eon_number=eon_number,
                         sender=account,
                         recipient=testrpc_accounts.accounts[0],
                         amount=initial_sender_balance - amount,
                         nonce=random.randint(1, 999999),
                         token=token)
    if initial_recipient_balance > 0:
        # clear recipient account
        send_transaction(test_case=test_case,
                         eon_number=eon_number,
                         sender=account,
                         recipient=testrpc_accounts.accounts[0],
                         amount=initial_recipient_balance,
                         nonce=random.randint(1, 999999),
                         token=token_swapped)

    sender_balance = sender_wallet_context.available_funds_at_eon(
        eon_number=eon_number, only_appended=False)
    recipient_balance = recipient_wallet_context.available_funds_at_eon(
        eon_number=eon_number, only_appended=False)

    test_case.assertEqual(sender_balance, amount)
    test_case.assertEqual(recipient_balance, 0)

    debit_balance_signatures = []
    debit_signatures = []
    credit_balance_signatures = []
    credit_signatures = []
    fulfillment_signatures = []

    for i in range(eon_count):
        swap = Transfer(wallet=sender_wallet,
                        amount=amount,
                        eon_number=eon_number + i,
                        recipient=recipient_wallet,
                        amount_swapped=amount_swapped,
                        nonce=nonce,
                        processed=False,
                        complete=False,
                        swap=True)

        sender_wallet_context = WalletTransferContext(wallet=sender_wallet,
                                                      transfer=swap)
        recipient_wallet_context = WalletTransferContext(
            wallet=recipient_wallet, transfer=swap)

        sender_highest_spent, sender_highest_gained = sender_wallet_context.off_chain_actively_sent_received_amounts(
            eon_number=eon_number + i, only_appended=False)

        if i == 0:
            tx_set_tree = sender_wallet_context.authorized_transfers_tree(
                only_appended=False, force_append=True)
        else:
            tx_set_tree = WalletTransferContext.authorized_transfers_tree_from_list(
                [
                    swap.shorthand(sender_wallet_context,
                                   is_last_transfer=True,
                                   starting_balance=sender_balance)
                ])

        tx_set_hash = hex_value(tx_set_tree.root_hash())

        debiting_active_state = ActiveState(
            wallet=sender_wallet,
            updated_spendings=sender_highest_spent + amount,
            updated_gains=sender_highest_gained,
            eon_number=eon_number + i,
            tx_set_hash=tx_set_hash)
        debiting_active_state_authorization = sign_message(
            debiting_active_state.checksum(), account.get('pk'))

        debiting_active_state_signature = Signature(
            wallet=sender_wallet,
            checksum=hex_value(debiting_active_state.checksum()),
            value=encode_signature(debiting_active_state_authorization))

        test_case.assertTrue(debiting_active_state_signature.is_valid())

        debit_concise_balance_marker = MinimumAvailableBalanceMarker(
            wallet=sender_wallet, eon_number=eon_number + i, amount=0)
        debit_concise_balance_marker_authorization = sign_message(
            debit_concise_balance_marker.checksum(), account.get('pk'))

        debit_concise_balance_marker_signature = Signature(
            wallet=sender_wallet,
            checksum=hex_value(debit_concise_balance_marker.checksum()),
            value=encode_signature(debit_concise_balance_marker_authorization))

        test_case.assertTrue(debit_concise_balance_marker_signature.is_valid())

        recipient_highest_spent, recipient_highest_gained = recipient_wallet_context.off_chain_actively_sent_received_amounts(
            eon_number=eon_number + i, only_appended=False)

        if i == 0:
            tx_set_tree = recipient_wallet_context.authorized_transfers_tree(
                only_appended=False, force_append=True)
        else:
            tx_set_tree = WalletTransferContext.authorized_transfers_tree_from_list(
                [
                    swap.shorthand(recipient_wallet_context,
                                   is_last_transfer=True,
                                   starting_balance=recipient_balance)
                ])

        tx_set_hash = hex_value(tx_set_tree.root_hash())

        crediting_active_state = ActiveState(
            wallet=recipient_wallet,
            updated_spendings=recipient_highest_spent,
            updated_gains=recipient_highest_gained,
            eon_number=eon_number + i,
            tx_set_hash=tx_set_hash)
        crediting_active_state_authorization = sign_message(
            crediting_active_state.checksum(), account.get('pk'))

        crediting_active_state_signature = Signature(
            wallet=recipient_wallet,
            checksum=hex_value(crediting_active_state.checksum()),
            value=encode_signature(crediting_active_state_authorization))

        test_case.assertTrue(crediting_active_state_signature.is_valid())

        credit_concise_balance_marker = MinimumAvailableBalanceMarker(
            wallet=recipient_wallet, eon_number=eon_number + i, amount=0)
        credit_concise_balance_marker_authorization = sign_message(
            credit_concise_balance_marker.checksum(), account.get('pk'))

        credit_concise_balance_marker_signature = Signature(
            wallet=recipient_wallet,
            checksum=hex_value(credit_concise_balance_marker.checksum()),
            value=encode_signature(
                credit_concise_balance_marker_authorization))

        test_case.assertTrue(
            credit_concise_balance_marker_signature.is_valid())

        swap.processed, swap.complete = True, True

        if i == 0:
            tx_set_tree = recipient_wallet_context.authorized_transfers_tree(
                only_appended=False, force_append=True)
        else:
            tx_set_tree = WalletTransferContext.authorized_transfers_tree_from_list(
                [
                    swap.shorthand(recipient_wallet_context,
                                   is_last_transfer=True,
                                   starting_balance=0)
                ])

        tx_set_hash = hex_value(tx_set_tree.root_hash())

        recipient_fulfillment_active_state = ActiveState(
            wallet=recipient_wallet,
            updated_spendings=recipient_highest_spent,
            updated_gains=recipient_highest_gained + amount_swapped,
            eon_number=eon_number + i,
            tx_set_hash=tx_set_hash)
        recipient_fulfillment_active_state_authorization = sign_message(
            recipient_fulfillment_active_state.checksum(), account.get('pk'))
        swap.processed, swap.complete = False, False

        recipient_fulfillment_active_state_signature = Signature(
            wallet=recipient_wallet,
            checksum=hex_value(recipient_fulfillment_active_state.checksum()),
            value=encode_signature(
                recipient_fulfillment_active_state_authorization))

        test_case.assertTrue(
            recipient_fulfillment_active_state_signature.is_valid())

        debit_balance_signatures.append({
            'value':
            encode_signature(debit_concise_balance_marker_authorization)
        })
        debit_signatures.append(
            {'value': encode_signature(debiting_active_state_authorization)})
        credit_balance_signatures.append({
            'value':
            encode_signature(credit_concise_balance_marker_authorization)
        })
        credit_signatures.append(
            {'value': encode_signature(crediting_active_state_authorization)})
        fulfillment_signatures.append({
            'value':
            encode_signature(recipient_fulfillment_active_state_authorization)
        })

    # Make API Request
    url = reverse('swap-endpoint')
    data = {
        'debit_signature': debit_signatures,
        'debit_balance_signature': debit_balance_signatures,
        'credit_signature': credit_signatures,
        'credit_balance_signature': credit_balance_signatures,
        'credit_fulfillment_signature': fulfillment_signatures,
        'eon_number': eon_number,
        'amount': amount,
        'amount_swapped': amount_swapped,
        'nonce': nonce,
        'wallet': {
            'address': sender_wallet.address,
            'token': sender_wallet.token.address,
        },
        'recipient': {
            'address': recipient_wallet.address,
            'token': recipient_wallet.token.address,
        },
        'sell_order': sell_order
    }

    # Send tx to server
    x = datetime.now()
    response = test_case.client.post(url, data, format='json')
    y = datetime.now()
    delta = y - x

    # Ensure the transaction was recorded
    test_case.assertEqual(response.status_code, expected_status,
                          response.content)

    print('SWAP Time: {}s for {}/{}'.format(delta, amount, amount_swapped))

    # assert that swap created for current eon is confirmed
    tx = json.loads(response.content)
    swap = Transfer.objects.get(id=tx['id'])
    test_case.assertEqual(swap.eon_number, eon_number)
    test_case.assertTrue(swap.is_signed_by_operator())

    # Log time delta
    return delta
Esempio n. 14
0
def send_transaction(test_case,
                     eon_number,
                     sender,
                     recipient,
                     amount,
                     nonce,
                     token,
                     expected_status=status.HTTP_201_CREATED):
    # Sender account
    sender_wallet = Wallet.objects.get(address=remove_0x_prefix(
        sender.get('address')),
                                       token=token)
    # Recipient account
    recipient_wallet = Wallet.objects.get(address=remove_0x_prefix(
        recipient.get('address')),
                                          token=token)

    transfer = Transfer(wallet=sender_wallet,
                        amount=amount,
                        eon_number=eon_number,
                        recipient=recipient_wallet,
                        nonce=nonce,
                        passive=True)

    sender_view_context = WalletTransferContext(wallet=sender_wallet,
                                                transfer=transfer)
    sender_highest_spent, sender_highest_gained = sender_view_context.off_chain_actively_sent_received_amounts(
        eon_number=eon_number, only_appended=False)
    updated_spendings = sender_highest_spent + amount

    # Authorize transaction
    transfer_set_root = hex_value(
        sender_view_context.authorized_transfers_tree_root(only_appended=False,
                                                           force_append=True))
    active_state = ActiveState(wallet=sender_wallet,
                               updated_spendings=updated_spendings,
                               updated_gains=sender_highest_gained,
                               eon_number=eon_number,
                               tx_set_hash=transfer_set_root)
    sender_active_state_authorization = sign_message(active_state.checksum(),
                                                     sender.get('pk'))

    sender_active_state_signature = Signature(
        wallet=sender_wallet,
        checksum=hex_value(active_state.checksum()),
        value=encode_signature(sender_active_state_authorization))

    test_case.assertTrue(sender_active_state_signature.is_valid())

    _, available_balance = sender_view_context.can_send_transfer(
        current_eon_number=eon_number, using_only_appended_funds=False)

    new_balance = available_balance - transfer.amount

    concise_balance_marker = MinimumAvailableBalanceMarker(
        wallet=sender_wallet, eon_number=eon_number, amount=new_balance)
    sender_concise_balance_marker_authorization = sign_message(
        concise_balance_marker.checksum(), sender.get('pk'))

    concise_balance_marker_signature = Signature(
        wallet=sender_wallet,
        checksum=hex_value(concise_balance_marker.checksum()),
        value=encode_signature(sender_concise_balance_marker_authorization))

    test_case.assertTrue(concise_balance_marker_signature.is_valid())

    print("Sender view:")
    print("available_balance:", available_balance)
    print("transfer_set_root:", transfer_set_root)
    print("active_state.updated_spendings:", active_state.updated_spendings)
    print("active_state.updated_gains:", active_state.updated_gains)

    # Make API Request
    url = reverse('transfer-endpoint')
    data = {
        'debit_signature': {
            'value': encode_signature(sender_active_state_authorization),
        },
        'debit_balance_signature': {
            'value':
            encode_signature(sender_concise_balance_marker_authorization),
        },
        'debit_balance': new_balance,
        'eon_number': eon_number,
        'amount': amount,
        'nonce': nonce,
        'wallet': {
            'address': sender_wallet.address,
            'token': sender_wallet.token.address,
        },
        'recipient': {
            'address': recipient_wallet.address,
            'token': recipient_wallet.token.address,
        },
    }

    # Send tx to server
    x = datetime.datetime.now()
    response = test_case.client.post(url, data, format='json')
    y = datetime.datetime.now()
    delta = y - x

    # Ensure the transaction was recorded
    test_case.assertEqual(response.status_code, expected_status,
                          '\n'.join([url,
                                     str(data),
                                     str(response.content)]))

    print('TX Time: {}s for {}'.format(delta, amount))

    # fo rpassive transfer assert that transaction is confirmed
    tx = json.loads(response.content)
    transfer = Transfer.objects.get(id=tx['id'])
    test_case.assertTrue(transfer.complete)
    test_case.assertTrue(transfer.appended)
    test_case.assertNotEqual(transfer.sender_active_state.operator_signature,
                             None)

    # Log time delta
    return delta