continuing basic hugo integration
This commit is contained in:
@@ -1,19 +1,17 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"git.assilvestrar.club/lourenco/go-hugo-cms.git/pkg/hugo"
|
||||||
|
|
||||||
"git.assilvestrar.club/lourenco/go-hugo-cms.git/pkg/git"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
options := git.GitOptions{
|
// options := git.GitOptions{
|
||||||
URL: "https://git.assilvestrar.club/lourenco/go-hugo-cms.git",
|
// URL: "https://git.assilvestrar.club/lourenco/go-hugo-cms.git",
|
||||||
Name: "go-hugo-cms",
|
// Name: "go-hugo-cms",
|
||||||
}
|
// }
|
||||||
|
|
||||||
err := options.Fetch()
|
hugo.List()
|
||||||
if err != nil {
|
//if err != nil {
|
||||||
fmt.Errorf("%w", err)
|
// fmt.Errorf("%w", err)
|
||||||
}
|
//}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,17 +3,30 @@ package hugo
|
|||||||
import (
|
import (
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"time"
|
||||||
"git.assilvestrar.club/lourenco/go-hugo-cms.git/pkg/git"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func (g *git.GitOptions) NewBlog() {
|
type Metadata struct {
|
||||||
if empty, _ := g.CheckIfEmpty(); !empty {
|
Path string
|
||||||
|
Slug string
|
||||||
|
Title string
|
||||||
|
Date *time.Time
|
||||||
|
ExpiryDate *time.Time
|
||||||
|
PublishDate *time.Time
|
||||||
|
Draft bool
|
||||||
|
Permalink string
|
||||||
|
Kind string
|
||||||
|
Section string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewBlog(name string) {
|
||||||
|
if empty, _ := CheckIfEmpty(name); !empty { // we need dir to be empty
|
||||||
log.Fatal("blog dir is not empty")
|
log.Fatal("blog dir is not empty")
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd := exec.Command("hugo", "new", "site", g.Name)
|
cmd := exec.Command("hugo", "new", "site", name)
|
||||||
if err := cmd; err != nil {
|
if err := cmd; err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
@@ -21,16 +34,41 @@ func (g *git.GitOptions) NewBlog() {
|
|||||||
cmd.Run()
|
cmd.Run()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *git.GitOptions) CheckIfEmpty() (bool, error) {
|
func CheckIfEmpty(name string) (bool, error) {
|
||||||
dir := os.Open(g.Name)
|
dir, err := os.Open(name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return false, err
|
return false, err
|
||||||
}
|
}
|
||||||
defer dir.Close()
|
defer dir.Close()
|
||||||
|
|
||||||
_, err := os.Readdirnames(1)
|
_, err = dir.Readdirnames(1)
|
||||||
if err == io.EOF {
|
if err == io.EOF {
|
||||||
return true, nil
|
return true, nil
|
||||||
}
|
}
|
||||||
return false, err
|
return false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Build() {
|
||||||
|
cmd := exec.Command("hugo", "build")
|
||||||
|
if err := cmd; cmd != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd.Run()
|
||||||
|
}
|
||||||
|
|
||||||
|
func List() {
|
||||||
|
if err := os.Chdir("/home/lv/dev/assilvestrar-blog"); err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd := exec.Command("hugo", "list", "all")
|
||||||
|
if err := cmd; cmd != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := cmd.Run(); err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user