Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/canhorn/Blazor.Contentful.Blog.Starter
A ASP.NET Core Blazor and Contentful blog site starter to get you up and running quickly with your new blog site.
https://github.com/canhorn/Blazor.Contentful.Blog.Starter
asp-net-core azure blazor demo-site
Last synced: 2 months ago
JSON representation
A ASP.NET Core Blazor and Contentful blog site starter to get you up and running quickly with your new blog site.
- Host: GitHub
- URL: https://github.com/canhorn/Blazor.Contentful.Blog.Starter
- Owner: canhorn
- Created: 2021-05-23T04:18:06.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-08-03T12:48:52.000Z (over 1 year ago)
- Last Synced: 2024-08-02T21:38:38.808Z (5 months ago)
- Topics: asp-net-core, azure, blazor, demo-site
- Language: C#
- Homepage: https://blazor-contentful-blog-starter.azurewebsites.net/
- Size: 1.16 MB
- Stars: 18
- Watchers: 2
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Blazor + Contentful Blog Starter
![A screenshot of the Next.js Contentful starter home page](screenshot.png)
This is an example repository for you to use to create a new blog site using Blazor and Contentful, using Contentful's .NET SDK.
[Read more about the .NET SDK](https://www.contentful.com/developers/docs/net/).
## View the demo site
[Click here to explore the demo site that uses this repository as its source code.](https://blazor-contentful-blog-starter.azurewebsites.net/)
## Deploy this site to Azure
The below Deploy to Azure will get you started with this template, when creating your instance you will need your Contentful API keys and Space Id, checkout the sections below to create them. After you can fill in your Contentful details and start the Creation.
There will be a little bit of a wait for the Azure Resources to be created and the initial build/deploy are done.[![Deploy to Azure](https://aka.ms/deploytoazurebutton)](https://portal.azure.com/#create/Microsoft.Template/uri/https%3A%2F%2Fraw.githubusercontent.com%2Fcanhorn%2FBlazor.Contentful.Blog.Starter%2Fmaster%2Fazure%2Fdeploy-to-azure.json)
## Getting set up
Fork the repository to your GitHub account and clone it to your local machine.
~~~bash
#using git
git clone [email protected]:canhorn/Blazor.Contentful.Blog.Starter.git#using the GitHub CLI
gh repo clone canhorn/Blazor.Contentful.Blog.Starter
~~~## Configuring your development environment
### Setup appsettings.json
At the root of the project, create a new `appsettings.Development.json` file. Add the following environment variable names to the file:
~~~json
{
"ContentfulOptions": {
"DeliveryApiKey": "",
"PreviewApiKey": "",
"SpaceId": ""
}
}
~~~### Using example content from Contentful
**You will need to provided your own Contentful account.**
### Creating your Contentful account
To get started with your own Contentful space, [sign up for free](https://www.contentful.com/sign-up/).
Create a new space inside your Contentful account. Go to Settings > General Settings, and make a note of your space ID.
![A screenshot of space ID settings in the Contentful UI](screenshot_space_id.png)
Generate a Content Delivery API access token for your Contentful space.
![A screenshot of access token settings in the Contentful UI](screenshot_access_token.png)
Add your space ID and access token to your `appsettings.Development.json` file.
## Importing the starter content model and example content into your own Contentful space
To get started quickly on your own version of the application, you can use the Contentful CLI to import the content model and the example content from the starter into your own Contentful space — without touching the Contentful UI!
### Install the Contentful CLI
~~~bash
#using homebrew
brew install contentful-cli#using npm
npm install -g contentful-cli#using yarn
yarn global add contentful-cli
~~~### Authenticate with the CLI
Open a terminal and run:
~~~bash
contentful login
~~~A browser window will open. Follow the instructions to log in to Contentful via the CLI.
### Import the content model and example content
The following command in your terminal, ensuring you switch out SPACE_ID for your new space ID.
~~~bash
cd Blazor.Contentful.Blog.Starter/Setupcontentful space import --space-id SPACE_ID --content-file content-export.json
~~~You should see this output in the terminal. The import will take around 1 minute to complete.
![A screenshot of the import command running in a terminal](screenshot_import_terminal.png)
Refresh Contentful in your browser, navigate to the content model tab, and you'll find the content types have been imported into your space. You'll find the example content by clicking on the content tab.
![A screenshot of the imported content model in the Contentful UI](screenshot_content_model.png)
## Running the application in development
Navigate to the project directory in a terminal window and run:
~~~bash
dotnet watch run
~~~## Cache Busting (WebHook registration)
After your Azure instance, or other chosen deployment method, you will need to register a WebHook, ```https:///webhook/cache-buster``` with Contentful. This WebHook is used by the Blazor Contentful Blog Starter application to know when it should clear its cache and request fresh CMS data from Contentful.
I will not go over this process on this repository, but you can check [Intro to webhooks](https://www.contentful.com/developers/docs/concepts/webhooks) for more details.
## Preview Environments
When you want to preview unpublished work from Contentful you will have to set the ```ContentfulOptions__UsePreviewApi``` app setting to ```true```. (example below) This will enable Preview Mode application wide, and API calls will pull in unpublished work.
This works great for creating a separate deployment website you can do work right no and when WebHooks are setup you will see the changes in realtime. If you use a local deployment and Ngrok to proxy the WebHook you can even develop new features!
~~~ json
{
"ContentfulOptions": {
"DeliveryApiKey": "...",
"PreviewApiKey": "...",
"SpaceId": "...",
"UsePreviewApi": true
}
}
~~~