xcode-simulator-cert/Sources/XcodeSimulatorKit/Commands/InstallCACommand.swift

63 lines
2.0 KiB
Swift

//
// Copyright © 2019 Simon Kågedal Reimer. See LICENSE.
//
import Foundation
import SPMUtility
class InstallCACommand: Command {
private struct Options {
var path: String?
var dryRun: Bool = false
}
let name = "install-ca"
let overview = "Install a Certificate Authority"
private let binder = ArgumentBinder<Options>()
private var options = Options()
private let filteringBinder = ArgumentBinder<FilteringOptions>()
private var filteringOptions = FilteringOptions()
func addOptions(to parser: ArgumentParser) {
binder.bind(option: parser.add(
option: "--dry-run",
kind: Bool.self,
usage: "Don't actually install any CA"
), to: { options, dryRun in
options.dryRun = dryRun
})
binder.bind(positional: parser.add(
positional: "path",
kind: String.self,
usage: "Path for the certificate to install"
), to: { options, path in
options.path = path
})
filteringBinder.bind(to: &filteringOptions, parser: parser)
}
func fillParseResult(_ parseResult: ArgumentParser.Result) throws {
try binder.fill(parseResult: parseResult, into: &options)
try filteringBinder.fill(parseResult: parseResult, into: &filteringOptions)
}
func run() throws {
let url = URL(fileURLWithPath: options.path!)
let certificate = try Certificate.load(from: url)
let certificateName = certificate.subjectSummary ?? "<unknown certificate>"
for device in try Simctl.flatListDevices().filter(using: filteringOptions) {
if options.dryRun {
print("Would install \(certificateName) into \(device.name).")
} else {
print("Installing \(certificateName) into \(device.name).")
let trustStore = TrustStore(uuid: device.udid)
try trustStore.open().addCertificate(certificate)
}
}
}
}