ADD: added basic backend function plus a mockup for a cli interface
This commit is contained in:
8
backend/cmd/cli/main.go
Normal file
8
backend/cmd/cli/main.go
Normal file
@@ -0,0 +1,8 @@
|
||||
// cmd/cli/main.go
|
||||
package main
|
||||
|
||||
import "studia/cmd/cli/root"
|
||||
|
||||
func main() {
|
||||
root.Execute()
|
||||
}
|
||||
25
backend/cmd/cli/root/root.go
Normal file
25
backend/cmd/cli/root/root.go
Normal file
@@ -0,0 +1,25 @@
|
||||
package root
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"studia/cmd/cli/user"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
var RootCmd = &cobra.Command{
|
||||
Use: "myapp",
|
||||
Short: "MyApp admin CLI",
|
||||
}
|
||||
|
||||
func Execute() {
|
||||
if err := RootCmd.Execute(); err != nil {
|
||||
fmt.Println(err)
|
||||
os.Exit(1)
|
||||
}
|
||||
}
|
||||
|
||||
func init() {
|
||||
RootCmd.AddCommand(user.UserCmd)
|
||||
}
|
||||
38
backend/cmd/cli/user/get.go
Normal file
38
backend/cmd/cli/user/get.go
Normal file
@@ -0,0 +1,38 @@
|
||||
// cmd/cli/user/get.go
|
||||
package user
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
// "studia/internal/db"
|
||||
usersvc "studia/internal/user"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
var id int64
|
||||
|
||||
var getCmd = &cobra.Command{
|
||||
Use: "get",
|
||||
Short: "Get user by ID",
|
||||
RunE: func(cmd *cobra.Command, args []string) error {
|
||||
database, err := db.New(getDSN())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
service := usersvc.NewService(database)
|
||||
user, err := service.GetByID(id)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
fmt.Printf("ID: %d\nEmail: %s\nName: %s\n",
|
||||
user.ID, user.Email, user.Name)
|
||||
return nil
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
getCmd.Flags().Int64Var(&id, "id", 0, "user ID")
|
||||
getCmd.MarkFlagRequired("id")
|
||||
}
|
||||
32
backend/cmd/cli/user/list.go
Normal file
32
backend/cmd/cli/user/list.go
Normal file
@@ -0,0 +1,32 @@
|
||||
// cmd/cli/user/list.go
|
||||
package user
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"myapp/internal/db"
|
||||
usersvc "myapp/internal/user"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
var listCmd = &cobra.Command{
|
||||
Use: "list",
|
||||
Short: "List users",
|
||||
RunE: func(cmd *cobra.Command, args []string) error {
|
||||
database, err := db.New(getDSN())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
service := usersvc.NewService(database)
|
||||
users, err := service.List()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
for _, u := range users {
|
||||
fmt.Printf("%d | %s | %s\n", u.ID, u.Email, u.Name)
|
||||
}
|
||||
return nil
|
||||
},
|
||||
}
|
||||
13
backend/cmd/cli/user/user.go
Normal file
13
backend/cmd/cli/user/user.go
Normal file
@@ -0,0 +1,13 @@
|
||||
package user
|
||||
|
||||
import "github.com/spf13/cobra"
|
||||
|
||||
var UserCmd = &cobra.Command{
|
||||
Use: "user",
|
||||
Short: "User management",
|
||||
}
|
||||
|
||||
func init() {
|
||||
UserCmd.AddCommand(listCmd)
|
||||
UserCmd.AddCommand(getCmd)
|
||||
}
|
||||
@@ -1,12 +1,23 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"studia/internal/server"
|
||||
|
||||
"log"
|
||||
"studia/internal/config"
|
||||
"studia/internal/server"
|
||||
)
|
||||
|
||||
func main() {
|
||||
|
||||
cfg := config.New()
|
||||
|
||||
cfg.DatabaseHost = "192.168.178.171"
|
||||
cfg.DatabasePort = "5432"
|
||||
cfg.DatabaseUser = "admin"
|
||||
cfg.DatabasePassword = "12345678"
|
||||
cfg.DatabaseName = "studia"
|
||||
|
||||
log.Println("Configuration loaded:", cfg)
|
||||
|
||||
log.Println("Starting server...")
|
||||
server.StartServer()
|
||||
server.StartServer(cfg)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user