Skip to main content

This package provides a few extra utilities for Python, like Asyncronus Encryption/Decryption.

Project description

ExtraUtils

25.07.2025: modified asyncTokens now asyncKeys (ansyncronus en- and decryption) will provide a bunch of small functionalities to speedup development.

(In active development, so if you have any suggestions, to make other developers life easier, feel free to submit them.)

Latest addition

TimeBasedToken()

Generates a time-based token using two keys: a primary and a secondary. Ideal for encrypting traffic between devices or services without sharing the actual tokens.

How it works:

  • Utilizes a unified timestamp, rounded to the nearest tenth of a second.
  • Uses the primary token as is.
  • Applies a transformation to the secondary token for added security.

Example:

primary = "1a2b3c4d5e6f7g8h9i0j1k2l3m4n5o6p"
secondary = "7q8r9s0t1u2v3w4x5y6z7a8b9c0d1e2f"
def main():
    final_token = TimeBasedToken(primary, secondary)

    print(final_token.regenerate())
    enc = final_token.encrypt("Hello World, i am going to be encrypted and decrypted again. : )")
    print(enc)
    dec = final_token.decrypt(enc)
    print(dec)

if __name__ == "__main__":
    main()

RateLimiter()

Limits the rate of operations to prevent overloading. Configurable thresholds, decay rates, and behaviors on limit reaching.

Example

# A very simplified example
from ExtraUtils import RateLimiter
rate_limit = RateLimiter(10,15,5,1,True)
# threshold (10) -> increments before rate_limit.hit is set to True
# upperCap (15) -> the highest value the trigger counter will go
# decay_rate (5) -> the amount in triggers to be decremented each decay cycle
# decay_time (1) -> the time in seconds between each decay cycle
# extreme_case (True) -> if an exeption should be raised (if True) or just rate_limit.hit set to True (if False)

def rate_limit_test(i:int):
    rate_limit.increment()
    print(i,rate_limit.hit)

for i in range(20):
    rate_limit_test(i)

# Output:	
#0 False
#(1 to 8) False
#9 False
#Traceback (most recent call last):
#  File "E:\Developement\RTS-Modules\ExtraUtils\showcase.py", line 14, in <module>
#    rate_limit_test(i)
#  File "E:\Developement\RTS-Modules\ExtraUtils\showcase.py", line 5, in rate_limit_test
#    rate_limiter.increment()
#  File "E:\Developement\RTS-Modules\ExtraUtils\ExtraUtils\RateLimit.py", line 30, in increment
#    raise RateLimited()
#ExtraUtils.RateLimit.RateLimited: Rate limit reached

Aditional methods are:

RateLimiter().pause_decay()
RateLimiter().resume_decay()

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

extrautilities-2.1.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

extrautilities-2.1-py3-none-any.whl (9.5 kB view details)

Uploaded Python 3

File details

Details for the file extrautilities-2.1.tar.gz.

File metadata

  • Download URL: extrautilities-2.1.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.13

File hashes

Hashes for extrautilities-2.1.tar.gz
Algorithm Hash digest
SHA256 db3ffc06ca89f580a4115c6e62b60ac2694011dc0d894d42be0e04908cebd61e
MD5 85ac2113df6a969de916f2ce36e6ef1f
BLAKE2b-256 b70b54c302ac417aef9862fc1cf248cae1218c2f0191ffcc77b0c0a633a394c1

See more details on using hashes here.

File details

Details for the file extrautilities-2.1-py3-none-any.whl.

File metadata

  • Download URL: extrautilities-2.1-py3-none-any.whl
  • Upload date:
  • Size: 9.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.13

File hashes

Hashes for extrautilities-2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f0ba9b7229302d75e42aa8dc317dc265b799073ffc3b0a2c627462d5d74a4e18
MD5 1328206a6cd1dae52d2d7d28ed8b97eb
BLAKE2b-256 390c19d150c4222ac73e675550f16e5a38c871c69b50396b997687fb5f1342d4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page