fiat

Spinnaker auth service

  • Owner: spinnaker/fiat
  • Platform:
  • License:: Apache License 2.0
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Spinnaker Auth Service

Build Status

   ____ _         ____ __    ___               _            ______                  _
  / __/(_)__ __  /  _// /_  / _, ___ _ ___ _ (_)___       /_  __/____ ___ _ _  __ (_)___
 / _/ / / \ \ / _/ / / __/ / __, / _ `// _ `// // _ \ _     / /  / __// _ `/, / // /(_-<
/_/  /_/ /_\_\ /___/ \__/ /_/, _, \_, / \_,_//_//_//_/( )   /_/  /_/   \_,_/, ___//_//___/
                                /___/, /

Fiat is the authorization server for the Spinnaker system.

It exposes a RESTful interface for querying the access permissions for a particular user. It currently supports three kinds of resources:

  • Accounts
  • Applications
  • Service Accounts

Accounts

Accounts are setup within Clouddriver and queried by Fiat for its configured requiredGroupMembership restrictions.

Applications

Applications are the combination of config metadata pulled from Front50 and server group names (e.g., application-stack-details). Application permissions sit beside application configuration in S3/Google Cloud Storage.

Service Accounts

Fiat Service Accounts are groups that act as a user during automated triggers (say, from a GitHub push or Jenkins build). Authorization is built in by making the service account a member of a group specified in requiredGroupMembership.


User Role/Authorization Providers

Currently supported user role providers are:

  • Google Groups (through a Google Apps for Work organization)
  • GitHub Teams
  • LDAP
  • File based role provider

Modular builds

By default, Fiat is built with all authorization providers included. To build only a subset of
providers, use the includeProviders flag:

./gradlew -PincludeProviders=google-groups,ldap clean build

You can view the list of all providers in gradle.properties.

Debugging

To start the JVM in debug mode, set the Java system property DEBUG=true:

./gradlew -DDEBUG=true

The JVM will then listen for a debugger to be attached on port 7103. The JVM will not wait for the debugger
to be attached before starting Fiat; the relevant JVM arguments can be seen and modified as needed in build.gradle.

Main metrics

Overview
Name With Ownerspinnaker/fiat
Primary LanguageJava
Program languageShell (Language Count: 5)
Platform
License:Apache License 2.0
所有者活动
Created At2016-06-14 16:44:56
Pushed At2025-04-09 04:50:12
Last Commit At2025-04-08 14:18:51
Release Count307
Last Release Namev1.57.0 (Posted on )
First Release Namev0.1.0 (Posted on )
用户参与
Stargazers Count70
Watchers Count42
Fork Count597
Commits Count1k
Has Issues Enabled
Issues Count0
Issue Open Count0
Pull Requests Count1043
Pull Requests Open Count8
Pull Requests Close Count91
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private