{"id":13594415,"url":"https://github.com/microsoft/dotnet-podcasts","last_synced_at":"2025-09-27T00:31:03.859Z","repository":{"id":37280045,"uuid":"426700184","full_name":"microsoft/dotnet-podcasts","owner":"microsoft","description":".NET reference application shown at .NET Conf featuring ASP.NET Core, Blazor, .NET MAUI, Microservices, Orleans, Playwright, and more!","archived":true,"fork":false,"pushed_at":"2024-05-02T22:24:51.000Z","size":14965,"stargazers_count":2749,"open_issues_count":7,"forks_count":746,"subscribers_count":165,"default_branch":"main","last_synced_at":"2024-09-23T18:02:06.666Z","etag":null,"topics":["asp-net-core","aspnetcore","blazor","csharp","dotnet","dotnet-maui","dotnetmaui","orleans","playwright","playwright-typescript","signalr","webapi"],"latest_commit_sha":null,"homepage":"https://dot.net","language":"C#","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/microsoft.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":"SUPPORT.md","governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2021-11-10T16:42:13.000Z","updated_at":"2024-09-21T05:07:09.000Z","dependencies_parsed_at":"2024-09-15T22:31:13.018Z","dependency_job_id":"98920aa8-87f2-46c5-a81e-484b0a0f4592","html_url":"https://github.com/microsoft/dotnet-podcasts","commit_stats":{"total_commits":572,"total_committers":47,"mean_commits":"12.170212765957446","dds":0.7884615384615384,"last_synced_commit":"5ee8be2990b81eb681bbd100875c263aaa5ab68a"},"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/microsoft%2Fdotnet-podcasts","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/microsoft%2Fdotnet-podcasts/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/microsoft%2Fdotnet-podcasts/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/microsoft%2Fdotnet-podcasts/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/microsoft","download_url":"https://codeload.github.com/microsoft/dotnet-podcasts/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":219871828,"owners_count":16554457,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["asp-net-core","aspnetcore","blazor","csharp","dotnet","dotnet-maui","dotnetmaui","orleans","playwright","playwright-typescript","signalr","webapi"],"created_at":"2024-08-01T16:01:33.154Z","updated_at":"2025-09-27T00:31:02.391Z","avatar_url":"https://github.com/microsoft.png","language":"C#","funding_links":[],"categories":["C#","Media","C\\#","dotnet","csharp"],"sub_categories":["Calculator"],"readme":"---\npage_type: sample\ndescription: \".NET reference application shown at .NET Conf 2021 \u0026 2022 featuring ASP.NET Core, Blazor, .NET MAUI, Microservices, Power Apps, Playwright, Orleans, and more!\"\nlanguages:\n- csharp\nproducts:\n- dotnet-core\n- ef-core\n- blazor\n- orleans\n- dotnet-maui\n- azure-sql-database\n- azure-storage\n- azure-container-apps\n- azure-container-registry\n- azure-app-service-web\n- playwright\n---\n\n# .NET Podcasts - Sample Application\n\nThe .NET Podcast app is a sample application showcasing [.NET](https://dotnet.microsoft.com/), [ASP.NET Core](https://dotnet.microsoft.com/apps/aspnet), [Blazor](https://dotnet.microsoft.com/apps/aspnet/web-apps/blazor), [.NET MAUI](https://dotnet.microsoft.com/apps/maui), [Azure Container Apps](https://azure.microsoft.com/services/container-apps/#overview), [Orleans](https://docs.microsoft.com/dotnet/orleans/overview), [Playwright](https://playwright.dev), and more.\n\nIn addition, we created an Approval App using [Microsoft Power Apps](https://docs.microsoft.com/en-us/power-apps/) to handle incoming podcast requests.\n\n![Logo](./docs/images/net-podcasts.png)\n\n\n## Application Architecture Diagram\n\n![.NET Podcast Application Diagram](./docs/images/arch_diagram_podcast.png)\n\n## Repositories\n\nFor this sample application, we build an app to listen to all your 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:\n\n- [Mobile \u0026 Desktop:](src/Mobile) Native .NET MAUI Application for iOS, Android, macOS, and Windows\n- [Website:](src/Web) Blazor WebAssembly app and ASP.NET Core Razor Marketing website\n- [Backend API:](src/Services) ASP.NET Core Web APIs \u0026 Minimal APIs, ingestion worker, and podcast update worker\n- [Blazor Hybrid App:](src/MobileBlazor) Sample hybrid application of .NET MAUI with Blazor.\n\nAdditionally, we build an application using [Microsoft Power Apps](https://docs.microsoft.com/en-us/power-apps/) to allow us to reject or accept incoming podcast requests:\n\n- [Microsoft Power Apps:](src/PowerApps) Power Apps sample to handle incoming podcast requests. [Follow these guidelines](src/PowerApps) on how to import the Approval Power App into your own Power Platform environment or [check out how to connect your API](docs/demos/powerapps) with the Microsoft Power Platform.\n\n## Full Deployment with GitHub Actions\n\n`dotnet-podcasts` repo is configured to deploy all services and websites automatically to Azure using GitHub Actions. [Follow the detailed guidelines](docs/deploy-websites-services.md) to setup GitHub Actions on your fork.\n\n## Local Deployment Quickstart\n\nThe easiest way to get started is to build and run the .NET Podcasts app service, database, and storage using Docker. \n\n1. First install [Docker Desktop](https://www.docker.com/products/docker-desktop)\n2. Clone the repository and navigate to the root directory in a terminal\n3. Run the following docker command (this may take some time to pull images, build, and deploy locally)\n\n```cli\ndocker-compose up\n```\n\n- *For Apple arm64-based system*:\n```cli\ndocker-compose -f docker-compose.arm64.yml -f docker-compose.override.yml up\n```\n\nThis will deploy and start all services required to run the web, mobile, and desktop apps. The Web API will run on `localhost:5003` and the SignalR Hub for listen together will run on `localhost:5001`.\n\n### Web, Mobile, \u0026 Desktop\n\nThe 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.\n\nEnsure that you have the following services running in Docker (podcast.api, listentogether.hub, podcast.updater.worker, podcast.db, storage):\n\n![Configured Docker services](docs/images/docker-app-config.png)\n\n### Backend Services\n\nOpen the [Services solution](src/Services) and pick a service to run locally such as the `Podcast.API`.\n\nEnsure that the following services are running in Docker, note that you only need the `podcast.db` and `storage`:\n\n![Configured Docker services](docs/images/docker-services-config.png)\n\n## Local Deployment with Visual Studio\n\n1. First install [Docker Desktop](https://www.docker.com/products/docker-desktop)\n2. Clone the repository and navigate to the root directory in a terminal\n3. Open the solution `NetPodcast.sln`, set the start project to `docker-compose` and hit F5. To optimize debugging while running all services, please refer to [Launch a subset of Compose services documentation.](https://docs.microsoft.com/visualstudio/containers/launch-profiles)\n4. By default, the Podcast.Api's swagger endpoint will be launched. Navigate to `localhost:5002` for the web application. If you see any errors, wait for a while and refresh the page.\n\n## Contributing\n\nThis project welcomes contributions and suggestions.  Most contributions require you to agree to a\nContributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us\nthe rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.\n\nWhen you submit a pull request, a CLA bot will automatically determine whether you need to provide\na CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions\nprovided by the bot. You will only need to do this once across all repos using our CLA.\n\nThis project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).\nFor more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or\ncontact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.\n\n## Trademarks\n\nThis project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft \ntrademarks or logos is subject to and must follow \n[Microsoft's Trademark \u0026 Brand Guidelines](https://www.microsoft.com/en-us/legal/intellectualproperty/trademarks/usage/general).\nUse of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship.\nAny use of third-party trademarks or logos are subject to those third-party's policies.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmicrosoft%2Fdotnet-podcasts","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmicrosoft%2Fdotnet-podcasts","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmicrosoft%2Fdotnet-podcasts/lists"}