1
0
mirror of https://github.com/strongdm/comply synced 2024-12-23 14:07:34 +00:00
Go to file
2021-10-15 08:29:11 +07:00
build Added package for missing fonts, otherwise updated pandoc 2 with pandoc -f markdown+smart doesn't work and throws a mktextfm ecrm1000 error (#46) 2018-06-15 11:49:45 -07:00
example Merge pull request #71 from rsogithub/master 2021-09-21 12:00:01 +02:00
fixtures Add tests to procedures, policies and standards (#48) 2021-10-13 15:04:20 -03:00
internal Fix for inconsistency between address we bind to and address we say we bind to (refs #113). 2021-10-15 08:29:11 +07:00
themes Merge pull request #80 from adamdecaf/2019-12-24-typos 2021-09-21 12:02:48 +02:00
vendor Update go.mod and adjust pandoc and watch usability (#64) 2021-10-06 14:33:14 -03:00
.gitignore Update go.mod and adjust pandoc and watch usability (#64) 2021-10-06 14:33:14 -03:00
AUTHORS.txt update authors 2018-12-17 14:43:00 -08:00
comply.go Initial commit 2018-05-15 14:13:11 -07:00
comply.rb Initial commit 2018-05-15 14:13:11 -07:00
Dockerfile prep port exposure from docker 2019-03-16 00:20:46 -07:00
go.mod Update go.mod and adjust pandoc and watch usability (#64) 2021-10-06 14:33:14 -03:00
go.sum Update go.mod and adjust pandoc and watch usability (#64) 2021-10-06 14:33:14 -03:00
LICENSE.txt Initial commit 2018-05-15 14:13:11 -07:00
logo.png logo (small) 2018-05-18 17:27:28 -07:00
Makefile go.mod: update dependencies 2020-09-14 11:08:56 -07:00
pdf-example.png Initial commit 2018-05-15 14:13:11 -07:00
README.md Improve documentation about Jira credentials (#95) 2021-10-08 16:05:11 +02:00
sc-1.gif Initial commit 2018-05-15 14:13:11 -07:00
sc-2.gif Initial commit 2018-05-15 14:13:11 -07:00
sc-3.gif Initial commit 2018-05-15 14:13:11 -07:00
sc-4.gif Initial commit 2018-05-15 14:13:11 -07:00
tools.go chore: migrate to go modules 2019-07-14 13:51:10 -03:00
VERSION increment patch for release (via Makefile) 2021-05-17 11:07:12 -07:00

Comply

Comply is a SOC2-focused compliance automation tool:

  • Policy Generator: markdown-powered document pipeline for publishing auditor-friendly policy documents
  • Ticketing Integration: automate compliance throughout the year via your existing ticketing system
  • SOC2 Templates: open source policy and procedure templates suitable for satisfying a SOC2 audit

Installation

macOS:

brew tap strongdm/comply; brew install comply

Linux:

Download latest release

Go users:

go get github.com/strongdm/comply

Get Started

Start with comply init:

$ mkdir my-company
$ cd my-company
$ comply init

Once comply init is complete, just git init and git push your project to a new repository. You're ready to begin editing the included policy boilerplate text.

Discussion

Join us in Comply Users

Screenshots

Demo video

Start a Project

screencast 1

Build PDFs

screencast 4 pdf example

Track Policy Coverage

screencast 3

Dashboard

screencast 2

Dependencies

Comply relies on pandoc, which can be installed directly as an OS package or invoked via Docker.

CLI

NAME:
   comply - policy compliance toolkit

USAGE:
   comply [global options] command [command options] [arguments...]

COMMANDS:
     init             initialize a new compliance repository (interactive)
     build, b         generate a static website summarizing the compliance program
     procedure, proc  create ticket by procedure ID
     scheduler        create tickets based on procedure schedule
     serve            live updating version of the build command
     sync             sync ticket status to local cache
     todo             list declared vs satisfied compliance controls
     help, h          Shows a list of commands or help for one command

Running in Docker

Comply is currently only released for Linux and macOS, however from other operating systems it's possible to run using Docker:

# first pull the latest published docker image
$ docker pull strongdm/comply

# from an empty directory that will contain your comply project
$ docker run --rm -v "$PWD":/source -p 4000:4000 -it strongdm/comply
root@ec4544732298:/source# comply init
✗ Organization Name:

# serve content live from an established project
$ docker run --rm -v "$PWD":/source -p 4000:4000 -it strongdm/comply
root@ae4d499583fc:/source# comply serve
Serving content of output/ at http://127.0.0.1:4000 (ctrl-c to quit)

For Windows users, replace $PWD with the full path to your project directory

Ticketing Integrations:

  • Jira
  • Github
  • Gitlab

Configuration

GitHub

Ticketing integration with GitHub can be configured with the following YAML in comply.yml:

tickets:
  github:
    repo: github.com/your-org/SOC2
    token: <token>
    username: org-bot-user

Also, GITHUB_REPO, GITHUB_TOKEN, and GITHUB_USERNAME can be used to override values from the YAML file.

Jira

When comply creates a ticket (through proc, for instance), it sets the following fields.

  • assignee
  • description
  • issuetype
  • labels
  • project key
  • reporter
  • summary

Please make sure that the default Create Screen has all of those fields enabled. Additionally, make sure that there are no other required fields for the issue type you choose.

About authentication, you need to create an API Token to use as a password.

Forking and local development

Assumes installation of golang and configuration of GOPATH in .bash_profile, .zshrc, etc Inspiration: http://code.openark.org/blog/development/forking-golang-repositories-on-github-and-managing-the-import-path

$ go get github.com/strongdm/comply
$ cd $GOPATH/src/github.com/strongdm/comply ; go get ./...
$ make
$ cd example
$ mv comply.yml.example comply.yml
$ ../comply -h
$ ../comply sync
$ ../comply serve
#
$ make # recompile as needed with in $GOPATH/src/github.com/strongdm/comply