Skip to content

🌟 Roadmap 🌟  #1510

@Lancetnik

Description

@Lancetnik

Roadmap

We know that some users are waiting for new broker support (like SQS/MQTT/etc.), but please be patient a bit longer.

Due to the inner project structure becoming much harder to change with each new broker, we are now focusing on stabilizing the inner and outer API. Then we will be able to promote new broker support in an easier way (like we used to do before).

Road to 1.0.0

Polish Current Features

First of all, we should polish already existing brokers and core features:

Inner Structure Refactoring

The next step is making Context non-global: we should pass it throughout the whole application from FastStream object -> Broker -> Subscriber -> Call. This step is also related to FastDepends 3.0 migration, and we can refactor dependency_overrides as well, and finally make Pydantic replaceable in serialization cases.

  • Optional Pydantic (0.6.0 #1779)
    • Migrate to FastDepends 3.0 (0.6.0 #1779)
    • Provide an option to use custom Serializer Protocol implementation (0.6.0 #1779)
  • Local dependency-overrides (0.6.0 #1779)
    • Migrate to FastDepends 3.0 (0.6.0 #1779)
    • Pass dependecy-overrides container from FastStream to the final consumers (0.6.0 #1779)
    • Complete Depends documentation by overrides section
  • Local context (0.6.0 #1779)
    • Refactor all parsers to get regex in init instead of using context
    • Refactor ContextType to use local context (0.6.0 #1779)
    • Pass context to FastDepends as kwargs (0.6.0 #1779)
    • Pass context from FastStream to the final consumers (0.6.0 #1779)
    • Refactor logging to not use raw context (0.6.0 #1779)
  • Finally, after all these steps, we can finalize the Middleware Public API (0.6.0 #1779)

New in Testing

We plan to refactor the In-Memory TestClient to make it side-effect-less (currently, it has some problems with reusing).

New Brokers Support

Finally, we can take a break from refactoring and add new broker support:

1.0.0 Finalization

At the end of the year (hopefully), we plan to release the first major version - 1.0.0

Community

Additionally, we are planning to start our Experts activity and provide users with a roadmap to study FastStream, a form to approve your expertise, and a public page with all approved experts to encourage people to help each other (and boost their resumes with the FastStream expert mark).

  • Launch Experts initiative

AsyncAPI

Last but not least, we should migrate to the new major AsyncAPI version

1.0.0 +

We are not looking too far ahead, but we have few thoughts:

Eventhough brokers are good, brokerless is much better, so ZMQ support looks promising to us

And the last thing - we want to provide you with some persistence layer (like Faust table or smth) to allow windowing incoming messages stream.

  • Incoming stream windowing

P.S. This plan is still pretty raw, and we can swap any of these points, but this is the general direction.

Metadata

Metadata

Labels

No labels
No labels

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions