2016-01-26 17:59:46 +00:00
|
|
|
class Cfssl < Formula
|
|
|
|
desc "CloudFlare's PKI toolkit"
|
|
|
|
homepage "https://cfssl.org/"
|
2016-03-29 23:51:22 +00:00
|
|
|
url "https://github.com/cloudflare/cfssl/archive/1.2.0.tar.gz"
|
2016-04-01 14:57:25 +00:00
|
|
|
sha256 "28e1d1ec6862eb926336490e2fcd1de626113d3e227293a4138fec59b7b6e443"
|
2016-04-07 14:54:04 +00:00
|
|
|
revision 2
|
|
|
|
|
2016-01-26 17:59:46 +00:00
|
|
|
head "https://github.com/cloudflare/cfssl.git"
|
|
|
|
|
2016-01-28 11:27:31 +00:00
|
|
|
bottle do
|
2016-03-30 00:20:44 +00:00
|
|
|
cellar :any_skip_relocation
|
2016-05-03 20:17:29 +00:00
|
|
|
revision 1
|
|
|
|
sha256 "0d71b15ea2122abb7b50ca92ca0ef29d6e92faec00a7358cd4fc9212bcd8f917" => :el_capitan
|
|
|
|
sha256 "d53c26a753af41df8638eac07f7ae4c6bef90dd8304c2fbd03d4afed4a52b9a9" => :yosemite
|
|
|
|
sha256 "c351aac8d82c5484d60379be71a1a6e65f8cde09e3d28356087cdc2619aa2de7" => :mavericks
|
2016-01-28 11:27:31 +00:00
|
|
|
end
|
|
|
|
|
2016-01-26 17:59:46 +00:00
|
|
|
depends_on "go" => :build
|
|
|
|
depends_on "libtool" => :run
|
|
|
|
|
|
|
|
def install
|
|
|
|
ENV["GOPATH"] = buildpath
|
|
|
|
cfsslpath = buildpath/"src/github.com/cloudflare/cfssl"
|
|
|
|
cfsslpath.install Dir["{*,.git}"]
|
|
|
|
cd "src/github.com/cloudflare/cfssl" do
|
|
|
|
system "go", "build", "-o", "#{bin}/cfssl", "cmd/cfssl/cfssl.go"
|
|
|
|
system "go", "build", "-o", "#{bin}/cfssljson", "cmd/cfssljson/cfssljson.go"
|
2016-05-03 17:43:15 +00:00
|
|
|
system "go", "build", "-o", "#{bin}/cfsslmkbundle", "cmd/mkbundle/mkbundle.go"
|
2016-01-26 17:59:46 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-05-03 17:43:15 +00:00
|
|
|
def caveats; <<-EOS.undent
|
|
|
|
`mkbundle` has been installed as `cfsslmkbundle` to avoid conflict
|
|
|
|
with Mono and other tools that ship the same executable.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
2016-01-26 17:59:46 +00:00
|
|
|
test do
|
|
|
|
require "utils/json"
|
|
|
|
(testpath/"request.json").write <<-EOS.undent
|
|
|
|
{
|
|
|
|
"CN" : "Your Certificate Authority",
|
|
|
|
"hosts" : [],
|
|
|
|
"key" : {
|
|
|
|
"algo" : "rsa",
|
|
|
|
"size" : 4096
|
|
|
|
},
|
|
|
|
"names" : [
|
|
|
|
{
|
|
|
|
"C" : "US",
|
|
|
|
"ST" : "Your State",
|
|
|
|
"L" : "Your City",
|
|
|
|
"O" : "Your Organization",
|
|
|
|
"OU" : "Your Certificate Authority"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
EOS
|
|
|
|
shell_output("#{bin}/cfssl genkey -initca request.json > response.json")
|
|
|
|
response = Utils::JSON.load(File.read(testpath/"response.json"))
|
2016-05-03 17:39:19 +00:00
|
|
|
assert_match(/^-----BEGIN CERTIFICATE-----.*/, response["cert"])
|
|
|
|
assert_match(/.*-----END CERTIFICATE-----$/, response["cert"])
|
|
|
|
assert_match(/^-----BEGIN RSA PRIVATE KEY-----.*/, response["key"])
|
|
|
|
assert_match(/.*-----END RSA PRIVATE KEY-----$/, response["key"])
|
2016-01-26 17:59:46 +00:00
|
|
|
end
|
|
|
|
end
|