Mercurial > p > roundup > code
view roundup/cgi/timestamp.py @ 7068:bc06bad26872
Remove dead code for handling LogoutAction.
Dead code starts wih:
'''
# I think now that LogoutAction redirects to
# self.base ([tracker] web parameter in config.ini),
# this code is not needed. However I am keeping it
# around in case it has to come back to life.
# Delete if this is still around in 3/2018.
# rouilj 3/2017.
#
# Note using this code may cause a CSRF Login vulnerability.
# Handle the case where user logs out and tries to
# log in again in same window.
# The csrf token for the login button is associated
# with the prior login, so it will not validate.
| author | John Rouillard <rouilj@ieee.org> |
|---|---|
| date | Wed, 23 Nov 2022 22:25:34 -0500 |
| parents | 5ec3171580a6 |
| children | 07ce4e4110f5 |
line wrap: on
line source
'''Set of functions of adding/checking timestamp to be used to limit form submission for cgi actions. ''' import time, struct, binascii, base64 from roundup.cgi.exceptions import FormError from roundup.i18n import _ from roundup.anypy.strings import b2s, s2b def pack_timestamp(): return b2s(base64.b64encode(struct.pack("i", int(time.time()))).strip()) def unpack_timestamp(s): try: timestamp = struct.unpack("i", base64.b64decode(s2b(s)))[0] except (struct.error, binascii.Error, TypeError): raise FormError(_("Form is corrupted.")) return timestamp class Timestamped: def timecheck(self, field, delay): try: created = unpack_timestamp(self.form[field].value) except KeyError: raise FormError(_("Form is corrupted, missing: %s." % field)) if time.time() - created < delay: raise FormError(_("Responding to form too quickly.")) return True
