Add a better support for using reference in dapr components to make development easier #6965
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
This draft PR is the first step to provide better integration of dapr components with the concepts of aspire.
Currently this should be only considered as work in progress. I hope to get some feedback for this implementation.
The idea of the implementation is almost a year old and can be found here: #2735
Now let's get started on what the PR does and why it's important.
Short explanation of Dapr
Dapr is a framework that is build on basically 3 things:
Components from a developer perspective are files that configure a connection to a thridparty system that brings some defined purpose to your application. For example can you use RabbitMq as an Publisch and Subscribe Service to manage Events in your Application.
The Sidecar is a small application that sits next to your application and is used by your application, to talk to the configured components. The sidecar will load the component configuration files at startup.
Why this PR
Currently if you used dapr in your application and you wanted to use and configure your components, you needed to first install the 3rd Party systems on your development Machine, then write the component Configuration Files by your self.
After that befor your hit F5 in your Visual Studio you were forced to check if all your 3rd party systems are up and running so you will not a get an error when you sidecars start.
With this PR your are able for most dapr components (if they support connectionstrings), to define these 3rd party systems in your aspire.host and connect them in a common why to your sidecar.
So all you need todo now is hitting F5.
No scope of this PR
This PR doesn't focus on anything about deployment time. So even with this PR you can not just publish your dapr application and be happy. You still need to configure the dapr components manually.
Another issue is the very basic implementation of the secret store (see the dapr playground). It will more less only work with pre deployed secret stores or the local file secret store.
Fixes potentially the following issues
#4477
#3039
Checklist
<remarks />
and<code />
elements on your triple slash comments?breaking-change
template):doc-idea
template):cc @philliphoff
Microsoft Reviewers: Open in CodeFlow