mirror of
https://github.com/planetmint/planetmint.git
synced 2025-03-30 15:08:31 +00:00

* creating first github action Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fix syntax error Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * renamed action, using black stable Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated checkout action on workflow black Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * formatted code with black Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * replaced lint with black service Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed black service added black check to makefile Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * replaced flake8 with black Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added pull_request to black actions trigger Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * replaced flake8 with black style checker (#212) * updated version number to 1.0.0 Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * creating first github action Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fix syntax error Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * renamed action, using black stable Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated checkout action on workflow black Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * formatted code with black Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * version bumpt Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed some comments and unsused import Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * replaced lint with black service Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed black service added black check to makefile Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * replaced flake8 with black Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added pull_request to black actions trigger Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * started on unit test workflow Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed run step Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed typo Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * testing docker-compose Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * check docker-compose Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * try running pytest Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * check out -f Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed path Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * increased health check retries, added job dependency Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added path to docker-compose.yml to test action Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * moved container startup to test step Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added checkout step to test job Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * different kind of execution Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * checking build step Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed missing keyword Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added checkout to build step Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * storing artifacts Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added needs Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed Dockerfile-dev to python-slim Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added job matrix back in Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added abci to build job matrix Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated test job steps Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed typo Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * replaced docker exec with docker-compose exec for abci test Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added first version of acceptance and integration test action Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added runs-on Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed syntax error Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * reverted to docker exec Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added copyright notice and env to start container step Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * separated abci from non abci test job Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * renamed pytest workflow to unit-test Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added codecov workflow Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added pytest install to codecov step Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added pip install Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * moved codecov to unit-test Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * show files Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed paths Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed debug job steps Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * renamed black to lint, added audit workflow Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * checking if dc down is necessary Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed dc down step from acceptance and integration Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed lint error Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added tox documentation to github acitons (#226) * added documentation job Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added docs dependency install to docs workflow Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * add more dependencies Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * install rapidjson manually Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added python-rapidjson to docs requirements text Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed gh config on tox.ini Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added base58 to docs require Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed docs require to dev Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * reversed changes to docs require Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed gh to gh-actions Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * increased verbosity for debugging Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added -e docsroot manually Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed verbosity Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed travis ci files Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * changed audit step to trigger on schedule Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> Co-authored-by: enesturk <enes.m.turk@gmail.com>
157 lines
4.8 KiB
Python
157 lines
4.8 KiB
Python
import pytest
|
|
import json
|
|
import base58
|
|
from hashlib import sha3_256
|
|
from zenroom import zencode_exec
|
|
from cryptoconditions.types.ed25519 import Ed25519Sha256
|
|
from cryptoconditions.types.zenroom import ZenroomSha256
|
|
from planetmint.transactions.common.crypto import generate_key_pair
|
|
|
|
CONDITION_SCRIPT = """
|
|
Scenario 'ecdh': create the signature of an object
|
|
Given I have the 'keyring'
|
|
Given that I have a 'string dictionary' named 'houses' inside 'asset'
|
|
When I create the signature of 'houses'
|
|
Then print the 'signature'"""
|
|
|
|
FULFILL_SCRIPT = """Scenario 'ecdh': Bob verifies the signature from Alice
|
|
Given I have a 'ecdh public key' from 'Alice'
|
|
Given that I have a 'string dictionary' named 'houses' inside 'asset'
|
|
Given I have a 'signature' named 'signature' inside 'metadata'
|
|
When I verify the 'houses' has a signature in 'signature' by 'Alice'
|
|
Then print the string 'ok'"""
|
|
|
|
SK_TO_PK = """Scenario 'ecdh': Create the keypair
|
|
Given that I am known as '{}'
|
|
Given I have the 'keyring'
|
|
When I create the ecdh public key
|
|
When I create the bitcoin address
|
|
Then print my 'ecdh public key'
|
|
Then print my 'bitcoin address'"""
|
|
|
|
GENERATE_KEYPAIR = """Scenario 'ecdh': Create the keypair
|
|
Given that I am known as 'Pippo'
|
|
When I create the ecdh key
|
|
When I create the bitcoin key
|
|
Then print data"""
|
|
|
|
ZENROOM_DATA = {"also": "more data"}
|
|
|
|
HOUSE_ASSETS = {
|
|
"data": {
|
|
"houses": [
|
|
{
|
|
"name": "Harry",
|
|
"team": "Gryffindor",
|
|
},
|
|
{
|
|
"name": "Draco",
|
|
"team": "Slytherin",
|
|
},
|
|
],
|
|
}
|
|
}
|
|
|
|
metadata = {"units": 300, "type": "KG"}
|
|
|
|
|
|
def test_zenroom_signing():
|
|
|
|
biolabs = generate_key_pair()
|
|
version = "2.0"
|
|
|
|
alice = json.loads(zencode_exec(GENERATE_KEYPAIR).output)["keyring"]
|
|
bob = json.loads(zencode_exec(GENERATE_KEYPAIR).output)["keyring"]
|
|
|
|
zen_public_keys = json.loads(zencode_exec(SK_TO_PK.format("Alice"), keys=json.dumps({"keyring": alice})).output)
|
|
zen_public_keys.update(json.loads(zencode_exec(SK_TO_PK.format("Bob"), keys=json.dumps({"keyring": bob})).output))
|
|
|
|
zenroomscpt = ZenroomSha256(script=FULFILL_SCRIPT, data=ZENROOM_DATA, keys=zen_public_keys)
|
|
print(f"zenroom is: {zenroomscpt.script}")
|
|
|
|
# CRYPTO-CONDITIONS: generate the condition uri
|
|
condition_uri_zen = zenroomscpt.condition.serialize_uri()
|
|
print(f"\nzenroom condition URI: {condition_uri_zen}")
|
|
|
|
# CRYPTO-CONDITIONS: construct an unsigned fulfillment dictionary
|
|
unsigned_fulfillment_dict_zen = {
|
|
"type": zenroomscpt.TYPE_NAME,
|
|
"public_key": base58.b58encode(biolabs.public_key).decode(),
|
|
}
|
|
output = {
|
|
"amount": "10",
|
|
"condition": {
|
|
"details": unsigned_fulfillment_dict_zen,
|
|
"uri": condition_uri_zen,
|
|
},
|
|
"public_keys": [
|
|
biolabs.public_key,
|
|
],
|
|
}
|
|
input_ = {
|
|
"fulfillment": None,
|
|
"fulfills": None,
|
|
"owners_before": [
|
|
biolabs.public_key,
|
|
],
|
|
}
|
|
metadata = {"result": {"output": ["ok"]}}
|
|
token_creation_tx = {
|
|
"operation": "CREATE",
|
|
"asset": HOUSE_ASSETS,
|
|
"metadata": metadata,
|
|
"outputs": [
|
|
output,
|
|
],
|
|
"inputs": [
|
|
input_,
|
|
],
|
|
"version": version,
|
|
"id": None,
|
|
}
|
|
|
|
# JSON: serialize the transaction-without-id to a json formatted string
|
|
message = json.dumps(
|
|
token_creation_tx,
|
|
sort_keys=True,
|
|
separators=(",", ":"),
|
|
ensure_ascii=False,
|
|
)
|
|
|
|
# major workflow:
|
|
# we store the fulfill script in the transaction/message (zenroom-sha)
|
|
# the condition script is used to fulfill the transaction and create the signature
|
|
#
|
|
# the server should ick the fulfill script and recreate the zenroom-sha and verify the signature
|
|
|
|
message = zenroomscpt.sign(message, CONDITION_SCRIPT, alice)
|
|
assert zenroomscpt.validate(message=message)
|
|
|
|
message = json.loads(message)
|
|
fulfillment_uri_zen = zenroomscpt.serialize_uri()
|
|
|
|
message["inputs"][0]["fulfillment"] = fulfillment_uri_zen
|
|
tx = message
|
|
tx["id"] = None
|
|
json_str_tx = json.dumps(tx, sort_keys=True, skipkeys=False, separators=(",", ":"))
|
|
# SHA3: hash the serialized id-less transaction to generate the id
|
|
shared_creation_txid = sha3_256(json_str_tx.encode()).hexdigest()
|
|
message["id"] = shared_creation_txid
|
|
|
|
from planetmint.models import Transaction
|
|
from planetmint.transactions.common.exceptions import (
|
|
SchemaValidationError,
|
|
ValidationError,
|
|
)
|
|
|
|
try:
|
|
tx_obj = Transaction.from_dict(message)
|
|
except SchemaValidationError:
|
|
assert ()
|
|
except ValidationError as e:
|
|
print(e)
|
|
assert ()
|
|
|
|
print(f"VALIDATED : {tx_obj}")
|
|
assert (tx_obj == False) is False
|