Server block
| This documentation is for a previous version of Cerbos. Choose 0.46.0 from the version picker at the top right or navigate to https://docs.cerbos.dev for the latest version. | 
Listen addresses
By default the server will start an HTTP server on port 3592 and a gRPC server on 3593 that will listen on all available interfaces.
server:
  httpListenAddr: ":3592"
  grpcListenAddr: ":3593"server:
  httpListenAddr: "192.168.0.17:3592"
  grpcListenAddr: "192.168.0.17:3593"server:
  httpListenAddr: "unix:/var/sock/cerbos.http"
  grpcListenAddr: "unix:/var/sock/cerbos.grpc"server:
  httpListenAddr: "unix:/var/sock/cerbos.http"
  grpcListenAddr: "unix:/var/sock/cerbos.grpc"
  udsFileMode: 0o776Metrics
By default, Prometheus metrics are available to scrape from the /_cerbos/metrics HTTP endpoint. If you want to disable metrics reporting, set metricsEnabled to false.
server:
  metricsEnabled: falsePayload logging
For debugging or auditing purposes, you can enable request and response payload logging for each request.
| Enabling this setting affects server performance and could expose potentially sensitive data contained in the requests to anyone with access to the server logs. | 
server:
  logRequestPayloads: trueTransport layer security (TLS)
You can enable transport layer security (TLS) by defining the paths to the certificate and key file in the TLS section.
server:
  tls:
    cert: /path/to/certificate
    key: /path/to/private_key| For production use cases that require automatic certificate reloading, workload identities and other advanced features, we recommend running a proxy server such as Envoy, Ghostunnel or Traefik in front of the Cerbos server. | 
CORS
By default, CORS is enabled on the HTTP service with all origins allowed. You can disable CORS by setting server.cors.disabled to true. You can also restrict the list of allowed origins and headers by setting server.cors.allowedOrigins and server.cors.allowedHeaders respectively.
server:
  cors:
    allowedOrigins:
      - example.com
      - example.org
    allowedHeaders:
      - X-CUSTOMRequest limits
By default, each Cerbos API request can include a batch of 50 resources with up to 50 actions to be checked for each resource. This limit is in place to prevent the server from being overloaded by very large requests — which affects throughput and CPU,memory,I/O usage.
| Changing these settings could have a large impact on the performance and resource utilisation of Cerbos instances. | 
server:
  requestLimits:
    maxActionsPerResource: 50
    maxResourcesPerRequest: 50Enable Admin API
The Cerbos Admin API provides administration functions such as adding or updating policies (if the underlying storage engine supports it) to the running Cerbos instance. It is disabled by default.
Authentication is mandatory for the Admin API. See Cerbos Admin API documentation for more details.
| TLS should be enabled to ensure that credentials are transmitted securely over the network. We also highly recommend changing the default username and password when deploying Cerbos. | 
server:
  adminAPI:
    enabled: true
    adminCredentials:
      username: cerbos
      passwordHash: JDJ5JDEwJE5HYnk4cTY3VTE1bFV1NlR2bmp3ME9QOXdXQXFROGtBb2lWREdEY2xXbzR6WnoxYWtSNWNDCgo=Generating a password hash
Cerbos expects the password to be hashed with bcrypt and encoded with base64. This can be achieved using the htpasswd and base64 utilities available on most operating systems.
echo "cerbosAdmin" | htpasswd -niBC 10 cerbos | cut -d ':' -f 2 | base64 -w0| On MacOS, the  sh | 
| The output of the above command for a given password value is not deterministic. It will vary between invocations or between different machines. This is because the bcryptalgorithm uses a salt (random noise) to make password cracking harder. |