dotnet-podcasts/README.md

88 lines
4.9 KiB
Markdown
Raw Normal View History

2021-11-30 03:54:48 +08:00
# .NET Podcasts - Sample Application
2021-11-11 00:42:28 +08:00
2022-04-22 05:38:16 +08:00
We are happy to announce the release of .NET Podcast App: a sample application showcasing [.NET 6](https://dotnet.microsoft.com/download/dotnet/6.0), [ASP.NET Core](https://dotnet.microsoft.com/apps/aspnet), [Blazor](https://dotnet.microsoft.com/apps/aspnet/web-apps/blazor), [.NET MAUI](https://docs.microsoft.com/dotnet/maui/what-is-maui), [Azure Container Apps](https://azure.microsoft.com/services/container-apps/#overview), [Orleans](https://docs.microsoft.com/dotnet/orleans/overview), and more.
2021-11-30 03:54:48 +08:00
2022-04-22 05:36:54 +08:00
You can browse a [live running version of the .NET Podcasts app](https://dotnetpodcasts.azurewebsites.net/) powered by ASP.NET Core and Blazor. You can also see a [live Orleans dashboard](https://dotnetpodcasts-listentogether-hub.azurewebsites.net/dashboard) for the Listen together mode!
2021-12-02 01:44:54 +08:00
2021-11-30 03:54:48 +08:00
![Logo](./docs/net-podcasts.png)
2021-12-02 01:44:54 +08:00
## Build Status
| Project | Status |
| --- | --- |
|Website|![Build status](/../../actions/workflows/podcast-web.yml/badge.svg)|
|Web API|![Services Build status](/../../actions/workflows/podcast-api.yml/badge.svg)|
|Listen Together Hub| ![Services Build status](/../../actions/workflows/podcast-hub.yml/badge.svg) |
## Application Architecture Diagram
![.NET Podcast Application Diagram](docs/arch_diagram_podcast.png)
2021-11-30 03:54:48 +08:00
## Repositories
For this sample application, we build an app to listen all you favorite .NET podcasts for all the ecosystems: Web, Android, iOS, macOS and Windows. You can find the different apps separated by folders in this repo:
- [Mobile & Desktop:](src/Mobile) Native .NET MAUI Application for iOS, Android, macOS, and Windows
- [Website:](src/Web) Blazor WebAssembly app and ASP.NET Core Razor Marketing website
- [Backend API:](src/Services) ASP.NET Core Web APIs & Minimal APIs, injestion worker, and podcast update worker
- [Blazor Hybrid App:](src/MobileBlazor) Sample hybrid application of .NET MAUI with Blazor.
2021-12-02 01:44:54 +08:00
## Full Deployment with GitHub Actions
`dotnet-podcasts` repo is configured to deploy all services and websites automatically to Azure using GitHub Actions. [Follow the detailed guidelines](Deploy-websites-services.md) to setup GitHub Actions on your fork.
2021-11-30 03:54:48 +08:00
## Local Deployment Quickstart
The easiest way to get started is to build and run the .NET Podcasts app service, database, and storage using Docker.
1. First install [Docker Desktop](https://www.docker.com/products/docker-desktop)
2. Clone the repository and navigate to the root directory in a terminal
3. Run the following docker command (this may take some time to pull images, build, and deploy locally)
```cli
docker-compose up
```
This will deploy and start all services required to run the web, mobile, and desktop apps. The Web API will run on `localhost:5000` and the SignalR Hub for listen together will run on `localhost:5001`.
### Web, Mobile, & Desktop
The apps are configured to speak to `localhost` on the correct ports for each service. Simply open the [Web solution](src/Web#solution) or the [.NET MAUI solution](src/Mobile) and run the app.
Ensure that you have the following services running in Docker (podcast.api, listentogether.hub, podcast.updater.worker, podcast.db, storage):
![Configured Docker services](docs/docker/docker-app-config.png)
### Backend Services
Open the [Services solution](src/Services) and pick a service to run locally such as the `Podcast.API`.
Ensure that the following services are running in Docker, note that you only need the `podcast.db` and `storage`:
![Configured Docker services](docs/docker/docker-services-config.png)
2021-11-11 00:42:28 +08:00
## Contributing
This project welcomes contributions and suggestions. Most contributions require you to agree to a
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us
the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide
a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions
provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).
For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or
contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.
## Trademarks
This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft
trademarks or logos is subject to and must follow
[Microsoft's Trademark & Brand Guidelines](https://www.microsoft.com/en-us/legal/intellectualproperty/trademarks/usage/general).
Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship.
Any use of third-party trademarks or logos are subject to those third-party's policies.