Plug remaning postgres leaks
This commit is contained in:
parent
42c441c82d
commit
36e7d53173
@ -114,6 +114,7 @@ class SessionBase(Model):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def release_session(session=None):
|
def release_session(session=None):
|
||||||
|
session.flush()
|
||||||
session_key = str(id(session))
|
session_key = str(id(session))
|
||||||
if SessionBase.localsessions.get(session_key) != None:
|
if SessionBase.localsessions.get(session_key) != None:
|
||||||
logg.debug('destroying session {}'.format(session_key))
|
logg.debug('destroying session {}'.format(session_key))
|
||||||
|
@ -25,8 +25,9 @@ class AccountRole(SessionBase):
|
|||||||
address_hex = Column(String(42))
|
address_hex = Column(String(42))
|
||||||
|
|
||||||
|
|
||||||
|
# TODO:
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_address(tag):
|
def get_address(tag, session):
|
||||||
"""Get Ethereum address matching the given tag
|
"""Get Ethereum address matching the given tag
|
||||||
|
|
||||||
:param tag: Tag
|
:param tag: Tag
|
||||||
@ -34,14 +35,24 @@ class AccountRole(SessionBase):
|
|||||||
:returns: Ethereum address, or zero-address if tag does not exist
|
:returns: Ethereum address, or zero-address if tag does not exist
|
||||||
:rtype: str, 0x-hex
|
:rtype: str, 0x-hex
|
||||||
"""
|
"""
|
||||||
role = AccountRole.get_role(tag)
|
if session == None:
|
||||||
if role == None:
|
raise ValueError('nested bind session calls will not succeed as the first call to release_session in the stack will leave the db object detached further down the stack. We will need additional reference count.')
|
||||||
return zero_address
|
|
||||||
return role.address_hex
|
session = SessionBase.bind_session(session)
|
||||||
|
|
||||||
|
role = AccountRole.get_role(tag, session)
|
||||||
|
|
||||||
|
r = zero_address
|
||||||
|
if role != None:
|
||||||
|
r = role.address_hex
|
||||||
|
|
||||||
|
SessionBase.release_session(session)
|
||||||
|
|
||||||
|
return r
|
||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_role(tag):
|
def get_role(tag, session=None):
|
||||||
"""Get AccountRole model object matching the given tag
|
"""Get AccountRole model object matching the given tag
|
||||||
|
|
||||||
:param tag: Tag
|
:param tag: Tag
|
||||||
@ -49,20 +60,26 @@ class AccountRole(SessionBase):
|
|||||||
:returns: Role object, if found
|
:returns: Role object, if found
|
||||||
:rtype: cic_eth.db.models.role.AccountRole
|
:rtype: cic_eth.db.models.role.AccountRole
|
||||||
"""
|
"""
|
||||||
session = AccountRole.create_session()
|
session = SessionBase.bind_session(session)
|
||||||
role = AccountRole.__get_role(session, tag)
|
|
||||||
session.close()
|
role = AccountRole.__get_role(tag, session)
|
||||||
#return role.address_hex
|
|
||||||
|
SessionBase.release_session(session)
|
||||||
|
|
||||||
return role
|
return role
|
||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def __get_role(session, tag):
|
def __get_role(tag, session):
|
||||||
return session.query(AccountRole).filter(AccountRole.tag==tag).first()
|
q = session.query(AccountRole)
|
||||||
|
q = q.filter(AccountRole.tag==tag)
|
||||||
|
r = q.first()
|
||||||
|
session.flush()
|
||||||
|
return r
|
||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def set(tag, address_hex):
|
def set(tag, address_hex, session=None):
|
||||||
"""Persist a tag to Ethereum address association.
|
"""Persist a tag to Ethereum address association.
|
||||||
|
|
||||||
This will silently overwrite the existing value.
|
This will silently overwrite the existing value.
|
||||||
@ -74,16 +91,16 @@ class AccountRole(SessionBase):
|
|||||||
:returns: Role object
|
:returns: Role object
|
||||||
:rtype: cic_eth.db.models.role.AccountRole
|
:rtype: cic_eth.db.models.role.AccountRole
|
||||||
"""
|
"""
|
||||||
#session = AccountRole.create_session()
|
session = SessionBase.bind_session(session)
|
||||||
#role = AccountRole.__get(session, tag)
|
|
||||||
role = AccountRole.get_role(tag) #session, tag)
|
role = AccountRole.get_role(tag, session)
|
||||||
if role == None:
|
if role == None:
|
||||||
role = AccountRole(tag)
|
role = AccountRole(tag)
|
||||||
role.address_hex = address_hex
|
role.address_hex = address_hex
|
||||||
#session.add(role)
|
|
||||||
#session.commit()
|
SessionBase.release_session(session)
|
||||||
#session.close()
|
|
||||||
return role #address_hex
|
return role
|
||||||
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
@ -95,19 +112,16 @@ class AccountRole(SessionBase):
|
|||||||
:returns: Role tag, or None if no match
|
:returns: Role tag, or None if no match
|
||||||
:rtype: str or None
|
:rtype: str or None
|
||||||
"""
|
"""
|
||||||
localsession = session
|
session = SessionBase.bind_session(session)
|
||||||
if localsession == None:
|
|
||||||
localsession = SessionBase.create_session()
|
|
||||||
|
|
||||||
q = localsession.query(AccountRole)
|
q = session.query(AccountRole)
|
||||||
q = q.filter(AccountRole.address_hex==address)
|
q = q.filter(AccountRole.address_hex==address)
|
||||||
role = q.first()
|
role = q.first()
|
||||||
tag = None
|
tag = None
|
||||||
if role != None:
|
if role != None:
|
||||||
tag = role.tag
|
tag = role.tag
|
||||||
|
|
||||||
if session == None:
|
SessionBase.release_session(session)
|
||||||
localsession.close()
|
|
||||||
|
|
||||||
return tag
|
return tag
|
||||||
|
|
||||||
|
@ -52,7 +52,10 @@ class GasOracle():
|
|||||||
:returns: Etheerum account address
|
:returns: Etheerum account address
|
||||||
:rtype: str, 0x-hex
|
:rtype: str, 0x-hex
|
||||||
"""
|
"""
|
||||||
return AccountRole.get_address('GAS_GIFTER')
|
session = SessionBase.create_session()
|
||||||
|
a = AccountRole.get_address('GAS_GIFTER', session)
|
||||||
|
session.close()
|
||||||
|
return a
|
||||||
|
|
||||||
|
|
||||||
def gas_price(self, category='safe'):
|
def gas_price(self, category='safe'):
|
||||||
|
@ -50,6 +50,7 @@ argparser = argparse.ArgumentParser()
|
|||||||
argparser.add_argument('-p', '--provider', dest='p', type=str, help='web3 provider')
|
argparser.add_argument('-p', '--provider', dest='p', type=str, help='web3 provider')
|
||||||
argparser.add_argument('-c', type=str, default=config_dir, help='config file')
|
argparser.add_argument('-c', type=str, default=config_dir, help='config file')
|
||||||
argparser.add_argument('-q', type=str, default='cic-eth', help='queue name for worker tasks')
|
argparser.add_argument('-q', type=str, default='cic-eth', help='queue name for worker tasks')
|
||||||
|
argparser.add_argument('-r', type=str, help='CIC registry address')
|
||||||
argparser.add_argument('--abi-dir', dest='abi_dir', type=str, help='Directory containing bytecode and abi')
|
argparser.add_argument('--abi-dir', dest='abi_dir', type=str, help='Directory containing bytecode and abi')
|
||||||
argparser.add_argument('--trace-queue-status', default=None, dest='trace_queue_status', action='store_true', help='set to perist all queue entry status changes to storage')
|
argparser.add_argument('--trace-queue-status', default=None, dest='trace_queue_status', action='store_true', help='set to perist all queue entry status changes to storage')
|
||||||
argparser.add_argument('-i', '--chain-spec', dest='i', type=str, help='chain spec')
|
argparser.add_argument('-i', '--chain-spec', dest='i', type=str, help='chain spec')
|
||||||
@ -69,6 +70,7 @@ config.process()
|
|||||||
args_override = {
|
args_override = {
|
||||||
'ETH_ABI_DIR': getattr(args, 'abi_dir'),
|
'ETH_ABI_DIR': getattr(args, 'abi_dir'),
|
||||||
'CIC_CHAIN_SPEC': getattr(args, 'i'),
|
'CIC_CHAIN_SPEC': getattr(args, 'i'),
|
||||||
|
'CIC_REGISTRY_ADDRESS': getattr(args, 'r'),
|
||||||
'ETH_PROVIDER': getattr(args, 'p'),
|
'ETH_PROVIDER': getattr(args, 'p'),
|
||||||
'TASKS_TRACE_QUEUE_STATUS': getattr(args, 'trace_queue_status'),
|
'TASKS_TRACE_QUEUE_STATUS': getattr(args, 'trace_queue_status'),
|
||||||
}
|
}
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
|
|
||||||
6b69c14ec8e6b622aedfcaaa86ffa959e64f832e {"key":"make-fetch-happen:request-cache:https://registry.npmjs.org/-/npm/v1/security/audits/quick","integrity":null,"time":1613156363320}
|
|
Loading…
Reference in New Issue
Block a user