Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Democritus functions[1] for working with Python dictionaries.
[1] Democritus functions are simple, effective, modular, well-tested, and well-documented Python functions.
We use d8s
(pronounced "dee-eights") as an abbreviation for democritus
(you can read more about this here).
pip install d8s-dicts
You import the library like:
from d8s_dicts import *
Once imported, you can use any of the functions listed below.
def dict_filter_by_values(dictionary: dict, filter_function: Callable) -> dict:
"""."""
def dict_filter_by_keys(dictionary: dict, filter_function: Callable) -> dict:
"""."""
def is_dict(possible_dict: Any) -> bool:
"""Return whether or not the possible_dict is a dictionary."""
def dict_keys(dictionary: dict) -> List[Any]:
"""Get the dictionary's keys (as a list)."""
def is_valid_dict_key(key: Any) -> bool:
"""Return whether or not a dictionary could have the given key."""
def dict_values(dictionary: dict) -> List[Any]:
"""Get the dictionary's values (as a list)."""
def dict_has_value(dictionary: dict, value) -> bool:
"""Return whether or not the dictionary has the given value (without evaluating the value)."""
def dict_key_types(dictionary: dict) -> list:
"""Return a list with the type of each key in the dictionary."""
def dict_value_types(dictionary: dict) -> dict:
"""Return a dictionary with the same keys and the type of each value in place of the actual value."""
def dict_keys_with_value(dictionary: dict, value):
"""Find the key(s) in the dictionary which have the given value."""
def dict_sort_by_keys(dictionary: dict, **kwargs) -> collections.OrderedDict:
"""Sort the dictionary based on the dictionary's keys."""
def dict_sort_by_values(dictionary: dict, **kwargs) -> collections.OrderedDict:
"""Sort the dictionary based on the dictionary's values."""
def dicts_sort_by_value_at_key(dictionaries: List[Dict[Any, Any]], key, **kwargs) -> List[Dict[Any, Any]]:
"""Sort the given dictionaries (we are assuming that we get a list of dictionaries) based on each dictionary's value at the given key."""
def dict_flip(dictionary: dict, *, flatten_values: bool = False, flip_lists_and_sets: bool = False) -> dict:
"""Flip the dictionary's keys and values; all of the values become keys and keys become values."""
def dict_delistify_values(dictionary: dict) -> dict:
"""For all values in the given dictionary that are lists whose lengths are one, replace the list of length one with the value in the list."""
def dict_examples(n: int = 10, **kwargs) -> List[Dict[Any, Any]]:
"""Create n dictionary examples."""
def dict_add(dictionary: Dict[Any, List[Any]], key: Any, value: Any) -> Dict[Any, List[Any]]:
"""Add the given value to the dictionary at the given key. This function expects that all values of the dictionary parameter are lists."""
def dicts_diffs(dictionary_a: dict, dictionary_b: dict) -> list:
"""."""
def dict_copy_value_at_key(dictionary: dict, key: Any, new_key: Any) -> dict:
"""Copy the value at the given key into the new key."""
def dict_move_value_at_key(dictionary: dict, old_key: Any, new_key: Any) -> dict:
"""Move the given key and its values into the new key."""
def dict_key_delete(dictionary: dict, key: Any) -> dict:
"""Delete the given key from the given dictionary."""
def dict_delete_items(dictionary: dict, values_to_delete: List[Any] = None, keys_to_delete: List[Any] = None) -> dict:
"""Delete all items from the dictionary if the item's value is in values_to_delete or the item's key is in keys_to_delete."""
def dict_delete_empty_values(dictionary: dict) -> dict:
"""Delete all key-values pairs from the dictionary if the value is an empty strings, empty list, zero, False or None."""
def dict_keys_with_max_value(dictionary: dict) -> List[DictKeyType]:
"""."""
def dict_keys_with_min_value(dictionary: dict) -> List[DictKeyType]:
"""."""
def dict_value_with_max_key(dictionary: dict) -> Any:
"""."""
def dict_value_with_min_key(dictionary: dict) -> Any:
"""."""
👋 If you want to get involved in this project, we have some short, helpful guides below:
If you have any questions or there is anything we did not cover, please raise an issue and we'll be happy to help.
This package was created with Cookiecutter and Floyd Hightower's Python project template.
FAQs
Democritus functions for working with Python dictionaries.
We found that d8s-dicts 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.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.