Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
:code:genericfuncs
allows you to create functions which execute different
implementations depending on the arguments.
This module can be seen as a powerful improvement over Python 3's :code:singledispatch
:
Basic usage
from genericfuncs import generic
@generic
def func(a):
# default implementation
raise ValueError()
@func.when(lambda a: a.startswith('foo')):
def _impl_1(a):
return a.upper()
@func.when(lambda a: a.startswith('bar')):
def _impl_2(a):
return a.lower()
The first predicate that returns True has its mapped implementation invoked. Predicates are checked in order of definition.
Installation
:code:pip install genericfuncs
Advanced
Arguments are injected into predicates and implementations by their name. This means a predicate or implementation is able to specify only the arguments it needs. For example::
@generic
def multiple_params_func(a, b, c):
return a + b + c # default implementation
@multiple_params_func.when(lambda b: b > 10) # only inject argument `b` to the predicate
def _when_b_greater_than_10(a): # only inject `a` to the implementation
return a * 10
@multiple_params_func.when(lambda a, b: a % b == 0) # only inject `a` and `b`
def _when_a_divisible_by_c(a, b, c): # use all arguments
return a / b * c
However the call site must list all mandatory arguments, as usual in Python::
multiple_params_func(10, 20, 30) --> 100 # _when_b_great_than_10() invoked
multiple_params_func(4, 2, 'bla') --> 'blabla' # _when_a_divisible_by_c() invoked
multiple_params_func(0, 0, 0) --> 0 # default implementation invoked
When defining a predicate, one can list exception types that should not propagate if raised inside the predicate. For example::
@my_generic_func.when(lambda a: a > 10, ignored_errors=[TypeError])
def _implementation(a):
...
When invoking :code:my_generic_func(MyThing())
, a :code:TypeError
will be raised inside the predicate
because :code:MyThing
doesn't support :code:>
operator.
Normally, the error would propagate and crash the program.
Specifying :code:ignored_errors=[TypeError]
makes the error be silently ignored,
moving on to the next predicate.
FAQs
Dynamic dispatch over arbitrary predicates
We found that genericfuncs demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.