-
Notifications
You must be signed in to change notification settings - Fork 22
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[automated commit] Bump docs to version 1.13.1
- Loading branch information
1 parent
894492b
commit 12d3345
Showing
152 changed files
with
928 additions
and
14 deletions.
There are no files selected for viewing
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
183 changes: 183 additions & 0 deletions
183
versioned_docs/version-1.13.1/guides/environment-variables.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,183 @@ | ||
import NewApiProjectInstructions from '../getting-started/new-api-project-instructions.md'; | ||
|
||
# Using Environment Variables with Platformatic | ||
|
||
Applications built with Platformatic loosely follows [the twelve factor app methodology](https://12factor.net/). | ||
This guide will show how to make your application [configurable](https://12factor.net/config), while | ||
keeping your deployment environments as close as possible. | ||
|
||
## Environment Variables replacement | ||
|
||
In any Platformatic configuration file, you can always interpolate an environment variable inside a value: | ||
|
||
```json | ||
{ | ||
... | ||
"db": { | ||
"connectionString": "{DATABASE_URL}" | ||
} | ||
... | ||
} | ||
``` | ||
|
||
The replacement is done via [`pupa`](http://npm.im/pupa), before the JSON file is parsed. | ||
|
||
All Platformatic configuration files support Environment Variables replacement, i.e. | ||
env variables are supported in Platformatic Service, Platformatic DB, Platformatic Composer, Platformatic Runtime. | ||
|
||
### dotenv support | ||
|
||
[`dotenv`](http://npm.im/dotenv) is built in inside Platformatic, allowing you to create an envfile with | ||
all your environment variables, that is loaded automatically by Platformatic at startup. | ||
If a `.env` file exists it will automatically be loaded by Platformatic using | ||
[`dotenv`](https://github.com/motdotla/dotenv). For example: | ||
|
||
```plaintext title=".env" | ||
DATABASE_URL=sqlite://./db.sqlite | ||
``` | ||
|
||
The `.env` file must be located in the same folder as the Platformatic configuration | ||
file or in the current working directory. | ||
|
||
Environment variables can also be set directly on the command line, for example: | ||
|
||
```bash | ||
PLT_SERVER_LOGGER_LEVEL=debug npx platformatic start | ||
``` | ||
|
||
### Allowed Environment Variables | ||
|
||
All placeholders in a configuration must be available as an environment variable | ||
and must meet the allowed placeholder name rules. | ||
|
||
### Allowed placeholder names | ||
|
||
Only placeholder names prefixed with `PLT_`, or that are in this allow list, will be | ||
dynamically replaced in the configuration file: | ||
|
||
- `PORT` | ||
- `DATABASE_URL` | ||
|
||
This restriction is to avoid accidentally exposing system environment variables. | ||
An error will be raised by Platformatic if it finds a configuration placeholder | ||
that isn't allowed. | ||
|
||
The default allow list can be extended by passing a `--allow-env` CLI option with a | ||
comma separated list of strings, for example: | ||
|
||
```bash | ||
npx platformatic start --allow-env=HOST,SERVER_LOGGER_LEVEL | ||
``` | ||
|
||
If `--allow-env` is passed as an option to the CLI, it will be merged with the | ||
default allow list. | ||
|
||
### Placeholder wildcard | ||
|
||
You're also able to define a placeholder wildcard, with your own prefix, for example: | ||
|
||
```bash | ||
npx platformatic service start --allow-env=MY_NS_* | ||
# OR | ||
npx platformatic start --allow-env=MY_NS_* | ||
``` | ||
|
||
This will allow you to use placeholders like `{MY_NS_MY_VAR}`. | ||
|
||
## Adding a custom environment variable to a project | ||
|
||
### Create a Platformatic DB App | ||
|
||
<NewApiProjectInstructions/> | ||
|
||
This same tutorial applies to all other Platformatic tools. | ||
|
||
### Modify `platformatic.db.json` | ||
|
||
Add a `greeting` option inside your `plugins` configuration: | ||
|
||
```json | ||
{ | ||
... | ||
"plugins": { | ||
"paths": [ | ||
{ | ||
"path": "./plugins", | ||
"encapsulate": false, | ||
"options": { | ||
"greeting": "{PLT_GREETING}" | ||
} | ||
}, | ||
{ | ||
"path": "./routes" | ||
} | ||
] | ||
}, | ||
... | ||
} | ||
``` | ||
|
||
This new options will be available inside all the options passed to | ||
all plugins in the `plugins/` folder. | ||
|
||
### Decorate the Fastify instance | ||
|
||
Create a new `plugins/greeting.js` file, calling [fastify.decorate()](https://fastify.dev/docs/latest/Reference/Decorators/#decorators) | ||
to expose some functionality to other plugins: | ||
|
||
```js | ||
/// <reference path="../global.d.ts" /> | ||
'use strict' | ||
/** @param {import('fastify').FastifyInstance} fastify */ | ||
module.exports = async function (fastify, opts) { | ||
fastify.decorate('sayHello', sayHello) | ||
|
||
function sayHello (name) { | ||
return `${opts.greeting} ${name}` | ||
} | ||
} | ||
``` | ||
|
||
### Use it inside a route | ||
|
||
Create a new `routes/hello.js` file that uses the newly added functionality, like so: | ||
|
||
```js | ||
/// <reference path="../global.d.ts" /> | ||
'use strict' | ||
/** @param {import('fastify').FastifyInstance} fastify */ | ||
module.exports = async function (fastify, opts) { | ||
fastify.get('/hello', { | ||
schema: { | ||
querystring: { | ||
type: 'object', | ||
properties: { | ||
name: { type: 'string' } | ||
} | ||
}, | ||
required: ['name'] | ||
} | ||
}, async (request, reply) => { | ||
return fastify.sayHello(request.query.name) | ||
}) | ||
} | ||
``` | ||
|
||
### Add an environemnt variable | ||
|
||
Edit your `.env` file and add: | ||
|
||
``` | ||
PLT_GREETING=Hello | ||
``` | ||
|
||
Don't forget to add a default value to your `.env.sample`, as | ||
the `.env` file is not committed to the repository. | ||
|
||
### Run your application and test the new route | ||
|
||
Run your application with `npm start`, and then test the new route with: | ||
|
||
```bash | ||
curl 'http://localhost:3042/hello?name=matteo' | ||
``` |
File renamed without changes.
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
Binary file added
BIN
+67.8 KB
...1.13.1/platformatic-cloud/images/risk-engine/github-pr-graphql-queries-diff.png
Oops, something went wrong.
Binary file added
BIN
+57.7 KB
...-1.13.1/platformatic-cloud/images/risk-engine/github-pr-graphql-schema-diff.png
Oops, something went wrong.
Binary file added
BIN
+261 KB
....1/platformatic-cloud/images/risk-engine/github-pr-risk-calculation-comment.png
Oops, something went wrong.
Oops, something went wrong.