Compare commits

...

5 Commits

5 changed files with 32 additions and 8 deletions

View File

@@ -1 +1 @@
include **/data/ERC20.json **/data/GiftableToken.json **/data/GiftableToken.bin *requirements.txt CHANGELOG LICENSE WAIVER WAIVER.asc include **/data/ERC20.json **/data/GiftableToken.json **/data/GiftableToken.bin *requirements.txt CHANGELOG LICENSE WAIVER WAIVER.asc **/data/.chainlib

View File

@@ -1 +1,4 @@
from .factory import GiftableToken from .factory import GiftableToken
from .factory import bytecode
from .factory import create
from .factory import args

View File

@@ -24,16 +24,22 @@ class GiftableToken(TxFactory):
__abi = None __abi = None
__bytecode = None __bytecode = None
def constructor(self, sender_address, name, symbol, decimals, tx_format=TxFormat.JSONRPC): def constructor(self, sender_address, name, symbol, decimals, tx_format=TxFormat.JSONRPC, version=None):
code = GiftableToken.bytecode() code = self.cargs(name, symbol, decimals)
tx = self.template(sender_address, None, use_nonce=True)
tx = self.set_code(tx, code)
return self.finalize(tx, tx_format)
@staticmethod
def cargs(name, symbol, decimals, version=None):
code = GiftableToken.bytecode(version=version)
enc = ABIContractEncoder() enc = ABIContractEncoder()
enc.string(name) enc.string(name)
enc.string(symbol) enc.string(symbol)
enc.uint256(decimals) enc.uint256(decimals)
code += enc.get() code += enc.get()
tx = self.template(sender_address, None, use_nonce=True) return code
tx = self.set_code(tx, code)
return self.finalize(tx, tx_format)
@staticmethod @staticmethod
@@ -51,7 +57,7 @@ class GiftableToken(TxFactory):
@staticmethod @staticmethod
def bytecode(): def bytecode(version=None):
if GiftableToken.__bytecode == None: if GiftableToken.__bytecode == None:
f = open(os.path.join(data_dir, 'GiftableToken.bin')) f = open(os.path.join(data_dir, 'GiftableToken.bin'))
GiftableToken.__bytecode = f.read() GiftableToken.__bytecode = f.read()
@@ -97,3 +103,17 @@ class GiftableToken(TxFactory):
return tx return tx
def bytecode(**kwargs):
return GiftableToken.bytecode(version=kwargs.get('version'))
def create(**kwargs):
return GiftableToken.cargs(kwargs['name'], kwargs['symbol'], kwargs['decimals'], version=kwargs.get('version'))
def args(v):
if v == 'create':
return (['name', 'symbol', 'decimals'], ['version'],)
elif v == 'default' or v == 'bytecode':
return ([], ['version'],)
raise ValueError('unknown command: ' + v)

View File

@@ -1,3 +1,4 @@
confini~=0.6.1 confini~=0.6.1
chainlib-eth~=0.4.15 chainlib-eth~=0.4.15
chainlib~=0.4.8
potaahto~=0.1.1 potaahto~=0.1.1

View File

@@ -1,6 +1,6 @@
[metadata] [metadata]
name = eth-erc20 name = eth-erc20
version = 0.5.4 version = 0.5.5
description = ERC20 interface and simple contract with deployment script that lets any address mint and gift itself tokens. description = ERC20 interface and simple contract with deployment script that lets any address mint and gift itself tokens.
author = Louis Holbrook author = Louis Holbrook
author_email = dev@holbrook.no author_email = dev@holbrook.no