Privateer has been meticulously crafted with infrastructure engineers in mind. If you're seeking to validate your resources against regulations, taxonomies, or standards, Privateer is your trusted companion. With a user-friendly interface and powerful features, you can now effortlessly navigate the complexities of resource validation.
There are several key benefits to Privateer Plugins:
- Community-Driven Plugins: Our open development model ensures that Plugins are crafted and maintained collaboratively by the community, reflecting a wealth of expertise and insights.
- Comprehensive Resource Validation: Privateer empowers you to validate a diverse array of resources in a single execution. No more piecemeal validation processes; instead, experience efficiency and thoroughness in one go.
- Consistent Machine-Readable Output: Regardless of the specific Plugin, you're guaranteed a standardized, machine-readable test output. This consistency simplifies the automation and integration of test results, enabling seamless decision-making.
- Empowering Service Providers: Privateer finds its calling in projects like Compliant Financial Infrastructure and Common Cloud Controls within FINOS. Service providers can leverage Privateer Plugins developed by FINOS to certify resources for use in regulated industries, such as insurance and banking.
Run the following command to install Privateer using the provided install.sh script:
/bin/bash -c "$(curl -sSL https://raw.githubusercontent.com/privateerproj/privateer/03ced90caae9f3c9203eb7f82f2c46ccf2ff15fc/install.sh)"
Download the latest release from GitHub Releases.
To build privateer from source, follow these steps below:
-
Clone the Repository
git clone https://github.com/privateerproj/privateer.git cd privateer
-
Installing Dependencies
go mod tidy
-
Building Privateer
make release
Plugins are built and maintained by the community. Choose the plugin(s) that you wish to run, and install them to your binaries path.
- Default Path: $HOME/.privateer/bin
- Customize via CLI: Use
--binaries-path
in your CLI command to change the path to your binaries. - Customize via config: Specify a custom binaries path in your config via the top level value
binaries-path: your/bin/path
- Create a Configuration File: Craft a configuration file (e.g.,
config.yml
) that specifies the plugins you intend to run and any necessary configuration options. Include secrets and settings required by the plugin. Refer to the specific plugin's documentation for precise details. - Output Directory (Optional): If desired, define an output directory in your configuration. Privateer will generate log and result files for each plugin in this directory. Results files are available in both JSON and YAML formats.
- Advanced Config Management: Privateer's roadmap includes plans for integrating with systems like etcd and Consul to enhance configuration and secret management.
Note
If your configuration file is stored in a non-default location, specify its file path using the -c or --config flag.
loglevel: Debug
write-directory: sample_output
services:
my-cloud-service1:
plugin: example
test-suite:
- tlp_red
# - tlp_amber
# - tlp_green
# - tlp_clea
Here are some common commands you can use with Privateer:
-h
/--help
: Display help information about Privateer and its commands.run
: Execute the specified plugin(s).generate-plugin
: Automatically create the code for a plugin based on a FINOS Common Cloud Controls catalog.list
: Show plugins requested by your configuration and whether they're installed.list -a
: Show all plugins you have installed.
Privateer generates logs and results files for each plugin. The output location may be specified by -o
/ --output-dir
.
- Log Results:
<output_dir>/<plugin_name>/<plugin_name>.log
- Plugin Results:
<output_dir>/<plugin_name>/results.yaml
- Default Value:
$HOME/privateer/output
- Log Verbosity: Increase the verbosity of logs using the
-v
or--verbose
flag. - Silence Logs: Silence non-essential log information using the
-s
or--silent
flag.