Skip to main content

Library for building & signing transactions for the PolySwarm sidechain

Project description

polyswarm-transaction

Transaction module for building, signing, and verifying transactions for the db backed sidechain

Transactions

Structure

{
    "name": "<module>:<class>",
    "from": "<public key checksum address>",
    "data": {}
}

Transactions are made of three parts; name, from, and data

The name defines which transaction is being called. The server side is able to use that and verify that it can perform the requested transaction.

The from field is an ethereum address that tells us who sent the message. This address is confirmed with the signature so we can be absolutely certain who sent the transaction.

The data field is the arguments that are passed to the named Transaction.

Signatures

To remain compatible with existing ERC20 tokens, the signature scheme makes heavy use of existing web3 tools. The keys are all ethereum public-private secp256k1 keypairs, and it uses keccak as the hash function.

When we prepare for signing, we output the python dictionaries as a json string, and keep that string stored. This string allows us to ensure order is maintained in transit, which cannot be done when json is loaded. The string is then hashed with keccak, and the user's private key can sign the hashed message.

Use

The primary use case of this library is to define the protocol by which transactions are transmitted. By simply overriding Transaction one can build any transactions that will easily conform to the standard.

By default the following transactions are already defined.

  1. bounty.BountyTransaction
  2. bounty.AssertionTransaction
  3. bounty.VoteTransaction
  4. nectar.WithdrawalTransaction

Is also defined a transaction.CustomTransaction accepting a data_body that you may handcraft for testing purposes.

Using the sign() method, these transactions will be transformed into a json string and signature. This signature can be verified the ecrecover method on SignedTransaction

Build Transactions

import requests

from web3.auto import w3
from polyswarmtransaction.bounty import BountyTransaction

demo_account = w3.eth.account.from_key([0] * 32)


transaction = BountyTransaction(guid, reward, artifact, artifact_type, metadata, duration)
signed = transaction.sign(demo_account.key)

# Send as form data so server doesn't load json string
response = requests.post(server_url, data=signed.payload)
response.raise_for_status()

Verify Signed Transactions

from polyswarmtransaction import SignedTransaction
from polyswarmtransaction.bounty import BountyTransaction
from django.http import HttpResponse

def bounty_view():
    data = request.POST.dict()
    signed = SignedTransaction(**data)

    # Public key is verified during recovery
    address = signed.ecrecover()
    try:
        bounty_transaction = signed.transaction()
    except (UnsupportedTransactionError, ValueError, ValidationError, WrongSignatureError, InvalidSignatureError):
        return HttpResponse('', 400)

    if not isinstance(bounty_transaction, BountyTransaction):
        return HttpResponse('', 400)

    do_work(address, bounty_transaction)

Signing payloads from CLI

For testing purposes is possible to sign arbitrary JSON payloads from commandline. They will all be encapsulated on a CustomTransaction before signing.

Password should be provided via -p/--password or will be requested on /dev/tty

The payload should be JSON and you can pipe it from STDIN:

$ echo '"DEADBEEF"' | python -m polyswarmtransaction /path/to/keyfile -p mypassword
{"raw_transaction": "{\"name\": \"polyswarmtransaction.transaction:CustomTransaction\", \"from\": \"0x05328f171b8c1463eaFDACCA478D9EE6a1d923F8\", \"data\": \"DEADBEEF\"}", "signature": "0x182195b3f7734ff2bb54545f29c3a961885c95bed4b989d7e9866dacd07090f258cffe8b9e39fb97435cd10d0f4131e7de59b76fce3ce7e3aa70874da39c949600"}

Payload can also be provided from a file via --payload option. The file still needs to contain a valid JSON.

$ python -m polyswarmtransaction /path/to/keyfile --payload path/to/payload.json -p mypassword
{"raw_transaction": "{\"name\": \"polyswarmtransaction.transaction:CustomTransaction\", \"from\": \"0x05328f171b8c1463eaFDACCA478D9EE6a1d923F8\", \"data\": ... \"}", "signature": "0x6ff71bfc58aa72bf4c8b0388c44d5151456a52eb1f1bc6f4825034cb96d0f2a90aa10afb3dd7aada15799bfb7a25f342e3e04ec02830807fde9222ad385ef6e700"}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

polyswarm-transaction-0.4.1.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

polyswarm_transaction-0.4.1-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file polyswarm-transaction-0.4.1.tar.gz.

File metadata

  • Download URL: polyswarm-transaction-0.4.1.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.7.0 requests/2.22.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.8.3

File hashes

Hashes for polyswarm-transaction-0.4.1.tar.gz
Algorithm Hash digest
SHA256 16552c0b84f90f0ed10601394c00457029eb39bf935063430e908b278e43586c
MD5 32bb955cb7193daba085219ca66d67ab
BLAKE2b-256 aca96f8aab41a18492675906ef26353db894c8a6294326f8e09778f012d3e9fc

See more details on using hashes here.

File details

Details for the file polyswarm_transaction-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: polyswarm_transaction-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 8.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.7.0 requests/2.22.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.8.3

File hashes

Hashes for polyswarm_transaction-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 446f6aa18e26bd0806ad279a5cbb2dbfc437466fe904d8d34bf9f9a8662a29ad
MD5 1d2a1afe91a14b38cd7b97b3a6453c74
BLAKE2b-256 2a243ea2139db55077160c00f6e51ccab6a1639d21ab3c107d50987907265d2a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page