-
Notifications
You must be signed in to change notification settings - Fork 81
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Programming to an interface #149
Comments
Seems like def configure(binder):
binder.multibind(List[NewsFeedRetriever], to=[NewYorkTimesFeedRetriever, WashingtonPostFeedRetriever]
...
class NewFeedAggregator:
@inject
def __init__(self, feeders: List[NewFeedRetriever]) -> None:
... |
@jstasiak thanks for taking the time to look into it. What if I then have 2 Thank you! |
Hey there, so are you saying that multibind is only for the binding to Lists and Dicts? And it doesn't allow multiple bindings to the same interface? |
Yes, the answer is the same as with #123: there's only one binding of a particular interface to an implementation unless you generate (and use) multiple artificial interfaces with Now that PEP 593 is accepted and implemented in |
Interesting! Maybe this thread can became a feature request? And someone can pick it up when it can? I do believe something like what is described here is needed to make this library even better! |
FWIW I'm a contributor to wired which comes from the venerable I bring this up because it actually works with PEP 544 protocols. Those things, and the early mypy support for them, are freaky things. I was able to make an abstract Logo component for my pages, with a different implementations looked up based on the content/resource type of the current request. I ultimately backed off protocols because the combination with dataclasses was still raw for mypy. But I was encouraged enough that I: (a) might try to make it a formal part (with Just my two cents. If I was smart, I'd try to merge my work into this project. But the things it's doing are too freaky. |
Hello I've seen here https://pypi.org/project/injector/#history that there was a new release back in September but I am struggling to see what's changed, I was wondering if any work has been done or just planned in regards of this thread or there's no active plan atm to support "programming to an interface" as described above. Thank you! |
See the change log here: https://injector.readthedocs.io/en/latest/changelog.html. I'm not aware on anyone working on this and I don't intend to work on anything related (also it's not clear to me what really needs to be implemented in general). |
Hello thanks for the clarification and the link to the changlog! I wouldn't know how to better explain the problem with additional examples. You are right when you say that this issue is a repetition of #123 feel free to close this, if it helps reducing noise and you are not planning to add that functionality. Although imho in complex projects not having this level of flexibility (namely: multiple implementations of same interface) makes things quite hard and this library difficult to adopt (although that's just my experience) |
First of all, thanks for the library. It's a very good to see python moving towards this practices.
I have been playing with this library in conjunction with flask-injector (https://pypi.org/project/Flask-Injector - and thanks also for that) for a couple of months now, and I believe there are some limitations, if we want to follow and applies 3 principles from SOLID in large or particularly complex code base. Particularly, if I want to respect Liskov Subistitution , Interface segregation, and dependency inversion.
Some conversation was carried on here: #123
I thought about not opening this thread at all, as it appears from there that you are not necessarily going to support that kind of behaviour, but at the same time it's probably an healthy discussion to have as what is asked there it's a very good point, and ultimately will allow me (and others) to understand in which direction this library intends to go.
What do I want to do?
I want to define an interface (using an abstract class, implementing nothing in python via abc) that sets the same contract for all implementations to respect (using type hints and returns in order to be precise about the contract).
After that I want to be able to pass a particular implementation to the injection in the client code via composition, and possibly at construction time, using as type declaration the interface rather than the implementation.
eg.
app.py
After some months you get bored with the Washington post and you replace it with the guardian. All you need to do is
If I use
bind
I can always only bind one implementation!What is the best way to achieve this with Injector ?
The text was updated successfully, but these errors were encountered: