fabrica sdk
Project description
installation
The Fabrica SDK is currently only available on test PyPi. You can install the Fabrica SDK from test PyPi with:
pip install --index-url https://test.pypi.org/simple/ fabricasdk
configuration
The Fabrica SDK uses a config file to determine which network, network settings and account should be used when calling the SDK's methods.
Below is an example of a config file that uses the Rinkeby test network.
#rinkeby-config.json
{
"sender_address": "<sender_address>",
"private_key":"<priv_key>",
"cosigner_address": "<cosigner_address>",
"fabrica_api_url": null,
"fabrica_api_key": null,
"network_url": null,
"local_state_path": null
}
To instantiate the SDK with the above config file you can do the following:
from fabricasdk import FabricaSdk
fabrica = FabricaSdk(os.path.join(dirname, "rinkeby-config.json"))
Multisig Wallet Overview
The Fabrica SDK can be used with either a single ethereum account private/public key pair or with a multisig wallet that is generated by the SDK. The multisig wallet requires signing from 2 of 3 ethereum accounts before a transaction is executed.
A typical multisig wallet will consist of the following three signers:
-
The
sender_address
which is best thought of as the SDK user address. -
The
cosigner_address
which initially will be Fabrica's address. -
The
customer_address
which represents the account address of the end user.
The sender_address
and cosigner_address
are specified in the above mentioned config file.
To generate a multisig wallet for a new user you must do the following:
from fabricasdk import FabricaSdk
fabrica = FabricaSdk(os.path.join(dirname, "rinkeby-config.json"))
customer_address = "0x94bebe960a5de83911e901b309bd7dfb1cd7a679"
# multisig wallet created here
receipt = fabrica.factory.create(customer_address)
print(receipt)
Multisig Transaction vs Non-Multisig Transaction
All core methods in the Fabrica SDK can be called either via a multisig wallet or with a "non-multisig" wallet. In the case that you choose not to use a multisig wallet the SDK will atempt to execute the transaction using the sender_address
and private_key
specified the config file.
All core methods in the Fabrica SDK accept optional parameters cosign
and customer_address
. By default cosign=True
. When cosign=True
you must also include the customer_address
which is the public account associated with the user that is 1 of the 3 signers of the multsig wallet.
Example:
from fabricasdk import FabricaSdk
fabrica = FabricaSdk(os.path.join(dirname, "rinkeby-config.json"))
token_id = int(time.time())
customer_address = "0x94bebe960a5de83911e901b309bd7dfb1cd7a679"
# mints a token using a multisig wallet associated with the customer_address
fabrica.token.mint(token_id, "geoHash", "holdingEntity", "ipfs:/ipfs/whatever", customer_address=customer_address)
# mints a token using the sender_address and private_key specified in the config file
fabrica.token.mint(token_id, "geoHash", "holdingEntity", "ipfs:/ipfs/whatever", cosign=False)
Creating Token Metadata with the mint method
Metadata associated with a Fabrica Token is stored in a json object. The Fabrica SDK mint function allows you to either pass a dictionary of values that are used to create a metadata object which is stored on IPFS and referenced from the token or pass a URL to the method which points to an existing metadata object or.
Below is an example of minting a token using a) a dictionary of values and b) a metadata URL
from fabricasdk import FabricaSdk
fabrica = FabricaSdk(os.path.join(dirname, "rinkeby-config.json"))
token_id = int(time.time())
# mint a token passing a dictionary of values to create a metadata object
receipt = fabrica.token.mint(
token_id,
"geoHash",
"holdingEntity",
{"name": "this is the name", "description": "this is the description"},
cosign=False
)
# mint a token using a URL that points to an existing metadata object
receipt = fabrica.token.mint(token_id, "geoHash", "holdingEntity", "ipfs:/ipfs/QmaFWUrRKHbNqKcZfUmnVMB38sb8XWJiJ27S5vH1NsaEai", customer_address=customer_address)
The get_token() method can be used to verify and view the token that you just created
example:
from fabricasdk import FabricaSdk
fabrica = FabricaSdk(os.path.join(dirname, "rinkeby-config.json"))
print(fabrica.token.get_token("1"))
the return value should include both the core token data stored in the smart contract and the associated metadata.
example:
{'token_id': 1, 'geohash': '9q8zn2ez3uev', 'holding_entity': 'Fabrica 1', 'token_uri': 'https://ipfs.io/ipfs/Qmbh7EHR9EfPdWfwWB6tuKXjSGHWzVX36kp6e3TNmMfX3M', 'metadata': {'name': '1707 Jones Street', 'description': 'awesome property', 'formationDocURI': 'https://ipfs.io/ipfs/QmRnE2rQqKdE2Zus59ourBuEKy3BtHg7SYf9wyi9QdTnN8'}}
Usage non-multisig
Below are examples of how do perform the following basic functions with the sdk: minting a token, updating a token and transferring a token without a multisig wallet.
#minting a token
#create a unique token id
token_id = int(time.time())
customer_address = "0x94bebe960a5de83911e901b309bd7dfb1cd7a679"
#call the mint method of the SDK with a token id, geohash(string), holding entity(string), tokenuri (string)
#NOTE: the tokenURI points to a metadata object for the property(address, legal description and link to the formation legal document). Creation of the metadata object will be included in the next version of the SDK, along with conversion of lat/lng geocords to geohash.
receipt = fabrica.token.mint(token_id, "geoHash", "holdingEntity", "ipfs:/ipfs/whatever", cosign=False)
#verify that the token was successfully minted
token = fabrica.get_token(token_id)
print("token: {}".format(token))
#call the update method of the SDK with a token id, holding entity (string), and tokenuri (string)
receipt = fabrica.token.update_token(token_id, "otherEntity", "otherUri", cosign=False)
print(receipt)
#verify that the token was successfully updated
token = fabrica.token.get_token(token_id)
print("token: {}".format(token))
#call the transfer_from method of the SDK with the address of the existing token holder(your address), the address that you are sending the token to and the token_idself.
receipt = fabrica.token.transfer_from(<from_address>, <to_address>, token_id, cosign=False)
print(receipt)
token=fabrica.token.get_token(token_id)
print("token: {}".format(token))
Usage multisig
Below are examples of how do perform the following basic functions with the sdk: minting a token, updating a token and transferring a token with a multisig wallet (including creation of the multisig wallet).
#minting a token
#create a unique token id
token_id = int(time.time())
#set customer address. note: this should be a valid ethereum address
customer_address = "0x94bebe960a5de83911e901b309bd7dfb1cd7a679"
#create multisig wallet
receipt = fabrica.factory.create(customer_address)
print(receipt)
#call the mint method of the SDK using cosign with a token id, geohash(string), holding entity(string), tokenuri (string)
#NOTE: the tokenURI points to a metadata object for the property(address, legal description and link to the formation legal document). Creation of the metadata object will be included in the next version of the SDK, along with conversion of lat/lng geocords to geohash.
receipt = fabrica.token.mint(token_id, "geoHash", "holdingEntity", "ipfs:/ipfs/whatever", customer_address=customer_address )
#verify that the token was successfully minted
token = fabrica.get_token(token_id)
print("token: {}".format(token))
#call the update method of the SDK using cosign with a token id, holding entity (string), and tokenuri (string)
receipt = fabrica.token.update_token(token_id, "otherEntity", "otherUri", customer_address=customer_address)
print(receipt)
#verify that the token was successfully updated
token = fabrica.token.get_token(token_id)
print("token: {}".format(token))
#call the transfer_from method of the SDK using cosign with the address of the existing token holder(your address), the address that you are sending the token to and the token_idself.
receipt = fabrica.token.transfer_from(<from_address>, <to_address>, token_id, customer_address=customer_address)
print(receipt)
token=fabrica.token.get_token(token_id)
print("token: {}".format(token))
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
Built Distribution
Hashes for fabricasdk-0.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d1317d10b2df213300fa1d12b6d55a36e6344e5e7726b91837d2fc841504465d |
|
MD5 | 558dcb33ae6bfb0b29e831d631e9e43d |
|
BLAKE2b-256 | 02e9b18a85884ee8f40d1415816bb386cfc893bb3bece7a73c26603eaa82def3 |