2024-05-22 15:36:33 +02:00
|
|
|
/*
|
2024-05-23 10:42:39 +02:00
|
|
|
Copyright © 2024 raul <raul@bulgariu.xyz>
|
2024-05-22 15:36:33 +02:00
|
|
|
*/
|
|
|
|
|
2024-05-22 10:42:00 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"embed"
|
|
|
|
"fmt"
|
2024-05-23 10:42:39 +02:00
|
|
|
"log"
|
2024-06-04 15:45:32 +02:00
|
|
|
"math/rand/v2"
|
2024-05-22 15:02:58 +02:00
|
|
|
"net/http"
|
2024-05-22 16:10:38 +02:00
|
|
|
"os"
|
2024-05-23 10:42:39 +02:00
|
|
|
"strconv"
|
2024-05-22 15:36:33 +02:00
|
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"github.com/spf13/viper"
|
2024-05-22 10:42:00 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2024-05-24 10:22:56 +02:00
|
|
|
listenPort = "1302"
|
|
|
|
default_organization = "Empresa SL"
|
|
|
|
default_country = "ES"
|
|
|
|
default_province = "Valencia"
|
|
|
|
default_locality = "Valencia"
|
|
|
|
default_street_address = "C/Fake Address 123"
|
|
|
|
default_postal_code = "80085"
|
|
|
|
default_not_after = 10
|
|
|
|
default_rsa_bitsize = 3072
|
|
|
|
default_dns_name = "www.example.com"
|
2024-05-22 10:42:00 +02:00
|
|
|
)
|
|
|
|
|
2024-05-22 15:02:58 +02:00
|
|
|
//go:embed templates/**
|
|
|
|
var templateFolder embed.FS
|
2024-05-22 10:42:00 +02:00
|
|
|
|
2024-05-24 10:22:56 +02:00
|
|
|
func defaultHTML() {
|
|
|
|
vipDefOrg := viper.GetString("Web.default_organization")
|
|
|
|
if vipDefOrg != "" {
|
|
|
|
default_organization = vipDefOrg
|
|
|
|
}
|
|
|
|
vipDefCount := viper.GetString("Web.default_country")
|
|
|
|
if vipDefCount != "" {
|
|
|
|
default_country = vipDefCount
|
|
|
|
}
|
|
|
|
vipDefProv := viper.GetString("Web.default_province")
|
|
|
|
if vipDefProv != "" {
|
|
|
|
default_province = vipDefProv
|
|
|
|
}
|
|
|
|
vipDefLocal := viper.GetString("Web.default_locality")
|
|
|
|
if vipDefLocal != "" {
|
|
|
|
default_locality = vipDefLocal
|
|
|
|
}
|
|
|
|
vipDefStreet := viper.GetString("Web.default_street_address")
|
|
|
|
if vipDefStreet != "" {
|
|
|
|
default_street_address = vipDefStreet
|
|
|
|
}
|
|
|
|
vipDefPostal := viper.GetString("Web.default_postal_code")
|
|
|
|
if vipDefPostal != "" {
|
|
|
|
default_postal_code = vipDefPostal
|
|
|
|
}
|
|
|
|
vipNotAfter := viper.GetInt("Web.default_not_after")
|
|
|
|
if vipNotAfter != 0 {
|
|
|
|
default_not_after = vipNotAfter
|
|
|
|
}
|
|
|
|
vipRSA := viper.GetInt("Web.default_rsa_bitsize")
|
|
|
|
if vipRSA != 0 {
|
|
|
|
default_rsa_bitsize = vipRSA
|
|
|
|
}
|
|
|
|
vipDNS := viper.GetString("Web.default_dns_name")
|
|
|
|
if vipDNS != "" {
|
|
|
|
default_dns_name = vipDNS
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-05-22 10:42:00 +02:00
|
|
|
func server() {
|
2024-05-24 10:22:56 +02:00
|
|
|
defaultHTML()
|
2024-05-23 14:10:36 +02:00
|
|
|
gin.SetMode(gin.ReleaseMode)
|
2024-05-23 10:42:39 +02:00
|
|
|
home, err := os.UserHomeDir()
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error happened looking up user home directory: %v\n", err)
|
|
|
|
}
|
|
|
|
checkFolders(home)
|
2024-05-22 15:36:33 +02:00
|
|
|
lPort := viper.GetString("Server.port")
|
|
|
|
if lPort != "" {
|
|
|
|
listenPort = lPort
|
|
|
|
}
|
2024-05-22 10:42:00 +02:00
|
|
|
r := gin.Default()
|
2024-05-22 15:02:58 +02:00
|
|
|
LoadHTMLFromEmbedFS(r, templateFolder, "templates/*.html")
|
2024-05-24 07:59:10 +02:00
|
|
|
|
|
|
|
//r.Static("/css", "./cmd/templates/css")
|
|
|
|
r.StaticFileFS("/css/style.css", "./templates/css/style.css", http.FS(templateFolder))
|
2024-05-24 08:07:30 +02:00
|
|
|
r.StaticFileFS("/favicon.ico", "./templates/ico/favicon.ico", http.FS(templateFolder))
|
|
|
|
r.StaticFileFS("/favicon-32x32.png", "./templates/ico/favicon-32x32.png", http.FS(templateFolder))
|
|
|
|
r.StaticFileFS("/favicon-16x16.png", "./templates/ico/favicon-16x16.png", http.FS(templateFolder))
|
|
|
|
r.StaticFileFS("/apple-touch-icon.png", "./templates/ico/apple-touch-icon.png", http.FS(templateFolder))
|
|
|
|
r.StaticFileFS("/android-chrome-512x512.png", "./templates/ico/android-chrome-512x512.png", http.FS(templateFolder))
|
|
|
|
r.StaticFileFS("/android-chrome-192x192.png", "./templates/ico/android-chrome-192x192.png", http.FS(templateFolder))
|
|
|
|
r.StaticFileFS("/site.webmanifest", "./templates/ico/site.webmanifest", http.FS(templateFolder))
|
2024-05-22 15:02:58 +02:00
|
|
|
|
2024-05-22 10:42:00 +02:00
|
|
|
r.GET("/", returnIndex)
|
2024-05-22 16:10:38 +02:00
|
|
|
r.GET("/cacert", returnCacert)
|
2024-05-23 13:18:10 +02:00
|
|
|
r.GET("/download/:domain", returnCerts)
|
2024-05-23 10:42:39 +02:00
|
|
|
r.POST("/api/upload", getDomainRequest)
|
2024-05-22 15:02:58 +02:00
|
|
|
|
2024-05-22 10:42:00 +02:00
|
|
|
fmt.Printf("Listening on port %v...\n", listenPort)
|
2024-05-24 10:22:56 +02:00
|
|
|
if err := r.Run(":" + listenPort); err != nil {
|
|
|
|
log.Fatalf("Error occurred starting server: %v\n", err)
|
|
|
|
}
|
2024-05-22 10:42:00 +02:00
|
|
|
}
|
|
|
|
|
2024-05-22 16:10:38 +02:00
|
|
|
func returnCacert(c *gin.Context) {
|
|
|
|
home, err := os.UserHomeDir()
|
|
|
|
if err != nil {
|
|
|
|
e := fmt.Sprintf("Error happened fetching: %v\n", err)
|
|
|
|
c.String(http.StatusInternalServerError, e)
|
|
|
|
return
|
|
|
|
}
|
2024-05-24 09:16:50 +02:00
|
|
|
c.FileAttachment(home+"/.config/cert400/ca.crt", "cacert.cer")
|
2024-05-22 16:10:38 +02:00
|
|
|
}
|
|
|
|
|
2024-05-22 10:42:00 +02:00
|
|
|
func returnIndex(c *gin.Context) {
|
2024-05-24 10:22:56 +02:00
|
|
|
c.HTML(http.StatusOK, "templates/index.html", gin.H{
|
2024-06-04 15:45:32 +02:00
|
|
|
"default_serial_number": rand.IntN(20000-1) + 1,
|
2024-05-24 10:22:56 +02:00
|
|
|
"default_organization": default_organization,
|
|
|
|
"default_country": default_country,
|
|
|
|
"default_province": default_province,
|
|
|
|
"default_locality": default_locality,
|
|
|
|
"default_street_address": default_street_address,
|
|
|
|
"default_postal_code": default_postal_code,
|
|
|
|
"default_not_after": default_not_after,
|
|
|
|
"default_rsa_bitsize": default_rsa_bitsize,
|
|
|
|
"default_dns_name": default_dns_name,
|
|
|
|
})
|
2024-05-22 10:42:00 +02:00
|
|
|
}
|
2024-05-22 15:02:58 +02:00
|
|
|
|
2024-05-23 10:42:39 +02:00
|
|
|
func getDomainRequest(c *gin.Context) {
|
|
|
|
serNum, _ := c.GetPostForm("formSerNum")
|
|
|
|
serNumInt, err := strconv.Atoi(serNum)
|
|
|
|
if err != nil {
|
|
|
|
e := fmt.Sprint(err)
|
|
|
|
c.String(http.StatusInternalServerError, e)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
Org, _ := c.GetPostForm("formOrg")
|
|
|
|
Country, _ := c.GetPostForm("formCountry")
|
|
|
|
Province, _ := c.GetPostForm("formProv")
|
|
|
|
Locality, _ := c.GetPostForm("formLocal")
|
|
|
|
StreetAddr, _ := c.GetPostForm("formStreet")
|
|
|
|
PostCode, _ := c.GetPostForm("formPostal")
|
|
|
|
ExpiryTime, _ := c.GetPostForm("formAge")
|
|
|
|
ExpiryTimeInt, err := strconv.Atoi(ExpiryTime)
|
|
|
|
if err != nil {
|
|
|
|
e := fmt.Sprint(err)
|
|
|
|
c.String(http.StatusInternalServerError, e)
|
|
|
|
}
|
|
|
|
BitSize, _ := c.GetPostForm("formBit")
|
|
|
|
BitSizeInt, err := strconv.Atoi(BitSize)
|
|
|
|
if err != nil {
|
|
|
|
e := fmt.Sprint(err)
|
|
|
|
c.String(http.StatusInternalServerError, e)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
DNSName, _ := c.GetPostForm("formDNS")
|
|
|
|
certDownload, keyDownload, err := generateCert(serNumInt, Org,
|
|
|
|
Country, Province, Locality, StreetAddr,
|
|
|
|
PostCode, DNSName, ExpiryTimeInt, BitSizeInt)
|
|
|
|
if err != nil {
|
|
|
|
e := fmt.Sprint(err)
|
|
|
|
c.String(http.StatusInternalServerError, e)
|
|
|
|
return
|
|
|
|
}
|
2024-05-23 13:18:10 +02:00
|
|
|
result := fmt.Sprintf(`
|
|
|
|
<b>
|
|
|
|
<p align="center">
|
|
|
|
<a target="_blank" href="download/%v.key">Download privkey</a>
|
|
|
|
</p>
|
|
|
|
<p align="center">
|
|
|
|
<a target="_blank" href="download/%v.crt">Download cert</a>
|
|
|
|
</p>
|
|
|
|
</b>
|
|
|
|
`, DNSName, DNSName)
|
|
|
|
c.String(http.StatusOK, result)
|
|
|
|
//c.File(keyDownload)
|
|
|
|
|
|
|
|
fmt.Println(certDownload, keyDownload)
|
2024-05-23 10:42:39 +02:00
|
|
|
return
|
2024-05-22 15:02:58 +02:00
|
|
|
}
|
2024-05-23 13:18:10 +02:00
|
|
|
|
|
|
|
func returnCerts(c *gin.Context) {
|
|
|
|
domain := c.Param("domain")
|
|
|
|
base, err := os.UserHomeDir()
|
|
|
|
if err != nil {
|
|
|
|
e := fmt.Sprintf("Error happened finding user home directory: %v\n", err)
|
|
|
|
c.String(http.StatusInternalServerError, e)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
c.FileAttachment(base+"/.config/cert400/clientCertificates/"+domain, domain)
|
|
|
|
//c.File(base + "/.config/cert400/clientCertificates/" + domain + ".key")
|
|
|
|
}
|