Plug remaning postgres leaks

This commit is contained in:
nolash 2021-02-21 16:29:34 +01:00
parent 42c441c82d
commit 36e7d53173
Signed by untrusted user who does not match committer: lash
GPG Key ID: 21D2E7BB88C2A746
6 changed files with 50 additions and 32 deletions

View File

@ -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))

View File

@ -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

View File

@ -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'):

View File

@ -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'),
} }

View File

@ -1,2 +0,0 @@
6b69c14ec8e6b622aedfcaaa86ffa959e64f832e {"key":"make-fetch-happen:request-cache:https://registry.npmjs.org/-/npm/v1/security/audits/quick","integrity":null,"time":1613156363320}