Once you're ready to deploy to production it's time to hook up Alinea to a backend. Alinea exposes a handler that can be hosted on most Javascript runtimes (Node.js or edge/serverless functions). The handler needs access to a backend service that can authenticate users, store drafts and publish changes back to the git repository.
Create the CMS handler in the app folder.
import {cms} from '@/cms'
import {createHandler} from 'alinea/next'
const handler = createHandler(cms)
export const GET = handler
export const POST = handler
Update your CMS config to inform Alinea where the handler is located and where to generate the admin dashboard.
export const cms = createCMS({
// ... schema, workspaces
// Point to your Next.js website
baseUrl: {
development: 'http://localhost:3000'
},
handlerUrl: '/api/cms',
dashboardFile: 'admin.html',
// Enable live previews
preview: true
})
While building your project, an admin folder will be created together with the staticFile as defined within your CMS config. Exclude the admin path and the staticFile from git by adding them to your .gitignore file:
/public/admin*
Deploy your code and follow the instructions on /admin.html to configure your backend.