mirror of
https://github.com/gregtwallace/apc-p15-tool.git
synced 2025-01-22 16:14:09 +00:00
78 lines
1.6 KiB
Go
78 lines
1.6 KiB
Go
package app
|
|
|
|
import (
|
|
"apc-p15-tool/pkg/pkcs15"
|
|
"os"
|
|
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
// struct for receivers to use common app pieces
|
|
type app struct {
|
|
logger *zap.SugaredLogger
|
|
config *config
|
|
}
|
|
|
|
// actual application start
|
|
func Start() {
|
|
// make app w/ initial logger pre-config
|
|
initLogLevel := "debug"
|
|
app := &app{
|
|
logger: makeZapLogger(&initLogLevel),
|
|
}
|
|
|
|
// get config
|
|
app.getConfig()
|
|
|
|
// re-init logger with configured log level
|
|
app.logger = makeZapLogger(app.config.logLevel)
|
|
|
|
// break point for building additional alternate functions
|
|
|
|
// function: make p15 from pem files
|
|
|
|
// Read in PEM files
|
|
keyPem, err := os.ReadFile(*app.config.keyPemFilePath)
|
|
if err != nil {
|
|
app.logger.Fatalf("failed to read key file (%s)", err)
|
|
// FATAL
|
|
}
|
|
|
|
certPem, err := os.ReadFile(*app.config.certPemFilePath)
|
|
if err != nil {
|
|
app.logger.Fatalf("failed to read cert file (%s)", err)
|
|
// FATAL
|
|
}
|
|
|
|
p15, err := pkcs15.ParsePEMToPKCS15(keyPem, certPem)
|
|
if err != nil {
|
|
app.logger.Fatalf("failed to parse pem files (%s)", err)
|
|
// FATAL
|
|
}
|
|
|
|
// TEMP TEMP TEMP
|
|
p15File, err := p15.ToP15File()
|
|
if err != nil {
|
|
app.logger.Fatalf("failed to make p15 file (%s)", err)
|
|
// FATAL
|
|
}
|
|
|
|
// app.logger.Debug(hex.EncodeToString(p15File))
|
|
// app.logger.Debug(base64.RawStdEncoding.EncodeToString(p15File))
|
|
|
|
apcHeader, err := makeFileHeader(p15File)
|
|
if err != nil {
|
|
app.logger.Fatalf("failed to make p15 file header (%s)", err)
|
|
// FATAL
|
|
}
|
|
|
|
apcFile := append(apcHeader, p15File...)
|
|
|
|
err = os.WriteFile("./apctool.p15", apcFile, 0777)
|
|
if err != nil {
|
|
app.logger.Fatalf("failed to write apc p15 file (%s)", err)
|
|
// FATAL
|
|
}
|
|
|
|
// TEMP TEMP TEMP
|
|
}
|