Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
.. image:: https://img.shields.io/badge/license-public%20domain-ff69b4.svg :target: https://github.com/ZeroGachis/nurse#license
.. image:: https://img.shields.io/badge/pypi-v0.3.1-blue.svg :target: https://pypi.org/project/nurse/
Outline
1. `Overview <https://github.com/ZeroGachis/nurse#overview>`_
2. `Installation <https://github.com/ZeroGachis/nurse#installation>`_
3. `Usage <https://github.com/ZeroGachis/nurse#usage>`_
4. `License <https://github.com/ZeroGachis/nurse#license>`_
Overview
Nurse is a dependency injection framework with a small API that uses type annotations to manage dependencies in your codebase.
Installation
**Nurse** is a Python3-only module that you can install via `Poetry <https://github.com/sdispater/poetry>`_
.. code:: sh
poetry add nurse
It can also be installed with `pip`
.. code:: sh
pip3 install nurse
Usage
~~~~~
**Nurse** stores the available dependencies into a service catalog, that needs to be
filled-in generally at the startup of your application.
.. code:: python3
import nurse
# A user defined class that will be used accross your application
class Player:
@property
def name(self) -> str:
return "Leeroy Jenkins"
# Now, add it to nurse service catalog in order to use it later in your application
nurse.serve(Player())
By default, dependencies are referenced by their concrete type, but you can also serve them
via one of their parent class.
.. code:: python3
import nurse
class Animal:
pass
class AngryAnimal(Animal):
@property
def roar(self) -> str:
return "Grrr! 🦁"
nurse.serve(AngryAnimal(), through=Animal)
Once you filled-in the service catalog with your different components, your can declare them as dependencies
to any of your class.
.. code:: python3
@nurse.inject("player")
class Game:
player: Player
enemy: Animal
def welcome_hero(self):
print(f"Welcome {self.player.name} !")
def summon_monster(self):
print(self.enemy.roar)
Game = Game()
game.welcome_hero()
# Welcome Leeroy Jenkins !
game.summon_monster()
# Grrr! 🦁
Or in any function
.. code:: python3
@nurse.inject('enemy')
def summon_monster(enemy: Animal):
print(enemy.roar)
summon_monster()
# Grrr! 🦁
And it works with async function as well !
.. code:: python3
import asyncio
@nurse.inject('enemy')
async def summon_monster(enemy: Animal):
print(enemy.roar)
asyncio.run(summon_monster())
# Grrr! 🦁
Finally, you can also retrieve a service without using a decorator
.. code:: python3
enemy = nurse.get(Animal)
print(enemy.roar)
# Grrr! 🦁
License
~~~~~~~
**Nurse** is released into the Public Domain. 🎉
FAQs
A thoughtful dependency injection framework 💉
We found that nurse 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
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.