A sample app of Static Web Apps with Database connections for a React app and Azure SQL database
This project uses the database connections feature of Static Web Apps to provide the following functionality:
- CRUD access to database contents with REST or GraphQL
- Built-in authorization with Static Web Apps authentication
- Support for database relationships with GraphQL
- An Azure SQL database with the tables created
- NodeJS
- An Azure Static Web App resource
- Clone this repository
- Navigate to
library
directory & open with VSCode - Set the
DATABASE_CONNECTION_STRING
environment variable to your connection string in your terminal/cmd/powershell. Alternatively, paste your database connection string directly intoswa-db-connections/staticwebapp.database.config.json
(not recommended) (ensure that you remove this secret from your source code before pushing to GitHub/remote repository) - Run
swa start http://localhost:3000 --run "cd library-demo && npm i && npm start" swa-db-connections
cd library-demo && npm i && npm start
will install needed npm packages and run your React app--data-api-location swa-db-connections
indicates to the SWA CLI that your database connections configurations are in theswa-db-connections
folder Alternatively, you can start all these projects manually an make use of SWA CLI's other args
You can now use your Static Web App Library Demo Application. It supports authorization, such that anyone logged in with SWA CLI's authentication emulation with the admin
role will have CRUD
access, while anonymous users are limited to read
access. See the configurations detailed in staticwebapp.database.config.json
- Commit all your changes and push to your repository.
- You do not need to change your configuration file's
data-source
object, since this will be overwritten by your Static Web App resource when you connect a database. - (If you have paste your connection string directly in your configuration file, ensure that you remove it to avoid making your database connection string public)
- You do not need to change your configuration file's
- Go to your Static Web App resource in the portal. Go to the Database connection tab.
- Ensure that your database is ready for connection. It should be configured to accept network requests from Azure services. If you plan to use managed identity as a connection type, ensure that you've configured the managed identity within your database.
- Link your database to your default environment. Select your database & enter the credentials.
- Ensure your Azure database is configured to accept network requests
- Ensure that your configuration files have been placed in your repository and included in your build process.
- Ensure that your managed identity has been configured within your database.