Compare commits
8 Commits
43c4fe36c0
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 56ffba1883 | |||
| 8e7b0ab472 | |||
| b26de27165 | |||
| 50edeb07ca | |||
| 31c5c49589 | |||
| 51d8531792 | |||
| da19da2d63 | |||
| e1012c234c |
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
## Install
|
## Install
|
||||||
```shell
|
```shell
|
||||||
go install git.gogacoder.ru/NTO/crudgen/cmd/crudgen@v1.0.7
|
go install git.gogacoder.ru/NTO/crudgen/cmd/crudgen@v1.0.16
|
||||||
```
|
```
|
||||||
|
|
||||||
## Run
|
## Run
|
||||||
|
|||||||
@@ -4,30 +4,66 @@ import (
|
|||||||
"flag"
|
"flag"
|
||||||
"git.gogacoder.ru/NTO/crudgen/internal"
|
"git.gogacoder.ru/NTO/crudgen/internal"
|
||||||
"log"
|
"log"
|
||||||
|
"os/exec"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ImplementServices(mainPkgDir string, reimplement bool) {
|
func ImplementServices(mainPkgDir string, reimplement bool) (modified bool) {
|
||||||
modelsNames, err := internal.GetStructNames(filepath.Join(mainPkgDir, "models"))
|
modelsNames, err := internal.GetStructNames(filepath.Join(mainPkgDir, "models"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("Error: %s\n", err)
|
log.Printf("Error: %s\n", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
var wasModified bool
|
||||||
|
|
||||||
log.Printf("Found models: %v\n", modelsNames)
|
log.Printf("Found models: %v\n", modelsNames)
|
||||||
|
|
||||||
for _, modelName := range modelsNames {
|
for _, modelName := range modelsNames {
|
||||||
err := internal.ImplementService(mainPkgDir, modelName, reimplement)
|
codeModified, err := internal.ImplementService(mainPkgDir, modelName, reimplement)
|
||||||
|
if codeModified {
|
||||||
|
wasModified = true
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("Error implement service for model %s: %s\n", modelName, err)
|
log.Printf("Error implement service for model %s: %s\n", modelName, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return wasModified
|
||||||
|
}
|
||||||
|
|
||||||
|
func runPostHook(postHook *string, wasModified bool) {
|
||||||
|
if wasModified && postHook != nil && *postHook != "" {
|
||||||
|
log.Printf("Running post hook %s\n", *postHook)
|
||||||
|
args := strings.Fields(*postHook)
|
||||||
|
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
|
||||||
|
if len(args) == 0 {
|
||||||
|
log.Printf("Empty post hook %s\n", *postHook)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(args) == 1 {
|
||||||
|
cmd = exec.Command(args[0])
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command(args[0], args[1:]...)
|
||||||
|
}
|
||||||
|
|
||||||
|
output, err := cmd.CombinedOutput()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("Error running post hook for %s: %s\n", *postHook, err)
|
||||||
|
} else {
|
||||||
|
log.Printf("Post hook output: %s\n", string(output))
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
log.SetFlags(0)
|
log.SetFlags(0)
|
||||||
projectPath := flag.String("p", ".", "project path")
|
projectPath := flag.String("p", ".", "project path")
|
||||||
reimplement := flag.Bool("f", false, "pass -f to allow tool to overwrite exist functions and service structure")
|
reimplement := flag.Bool("f", false, "pass -f to allow tool to overwrite exist functions and service structure")
|
||||||
|
postHook := flag.String("h", "", "post hook to run command after code modifications")
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
ImplementServices(*projectPath, *reimplement)
|
wasModified := ImplementServices(*projectPath, *reimplement)
|
||||||
|
runPostHook(postHook, wasModified)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package internal
|
|||||||
|
|
||||||
const CreateRawTemplate = `func (service *{{.ServiceName}}) Create(item {{.EntityType}}) ({{.EntityType}}, error) {
|
const CreateRawTemplate = `func (service *{{.ServiceName}}) Create(item {{.EntityType}}) ({{.EntityType}}, error) {
|
||||||
utils.ReplaceEmptySlicesWithNil(&item)
|
utils.ReplaceEmptySlicesWithNil(&item)
|
||||||
err := dal.Author.Create(&item)
|
err := dal.{{.EntityType}}.Create(&item)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return item, err
|
return item, err
|
||||||
}
|
}
|
||||||
@@ -31,7 +31,7 @@ const GetByIdRawTemplate = `func (service *{{.ServiceName}}) GetById(id uint) (*
|
|||||||
const UpdateRawTemplate = `func (service *{{.ServiceName}}) Update(item {{.EntityType}}) ({{.EntityType}}, error) {
|
const UpdateRawTemplate = `func (service *{{.ServiceName}}) Update(item {{.EntityType}}) ({{.EntityType}}, error) {
|
||||||
utils.ReplaceEmptySlicesWithNil(&item)
|
utils.ReplaceEmptySlicesWithNil(&item)
|
||||||
|
|
||||||
_, err := dal.Author.Updates(&item)
|
_, err := dal.{{.EntityType}}.Updates(&item)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return item, err
|
return item, err
|
||||||
}
|
}
|
||||||
@@ -54,3 +54,13 @@ const CountRawTemplate = `func (service *{{.ServiceName}}) Count() (int64, error
|
|||||||
amount, err := dal.{{.EntityType}}.Count()
|
amount, err := dal.{{.EntityType}}.Count()
|
||||||
return amount, err
|
return amount, err
|
||||||
}`
|
}`
|
||||||
|
|
||||||
|
const SortedByOrderTemplate = `func (service *{{.ServiceName}}) SortedByOrder(fieldsSortingOrder []utils.SortField) ([]*{{.EntityType}}, error) {
|
||||||
|
return utils.SortByOrder(fieldsSortingOrder, {{.EntityType}}{})
|
||||||
|
}`
|
||||||
|
|
||||||
|
const SearchByAllStringFields = `func (service *{{.ServiceName}}) SearchByAllTextFields(phrase string) ([]*{{.EntityType}}, error) {
|
||||||
|
return utils.FindPhraseByStringFields[{{.EntityType}}](phrase, {{.EntityType}}{})
|
||||||
|
}`
|
||||||
|
|
||||||
|
var implementedMethods = []string{CreateMethod, GetAllMethod, GetByIdMethod, UpdateMethod, DeleteMethod, CountMethod, SortedByOrderMethod, SearchByAllStringFields}
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ const GetByIdMethod = "GetById"
|
|||||||
const UpdateMethod = "Update"
|
const UpdateMethod = "Update"
|
||||||
const DeleteMethod = "Delete"
|
const DeleteMethod = "Delete"
|
||||||
const CountMethod = "Count"
|
const CountMethod = "Count"
|
||||||
|
const SortedByOrderMethod = "SortedByOrder"
|
||||||
|
|
||||||
var RawTemplates = map[string]string{
|
var RawTemplates = map[string]string{
|
||||||
CreateMethod: CreateRawTemplate,
|
CreateMethod: CreateRawTemplate,
|
||||||
@@ -30,4 +31,6 @@ var RawTemplates = map[string]string{
|
|||||||
UpdateMethod: UpdateRawTemplate,
|
UpdateMethod: UpdateRawTemplate,
|
||||||
DeleteMethod: DeleteRawTemplate,
|
DeleteMethod: DeleteRawTemplate,
|
||||||
CountMethod: CountRawTemplate,
|
CountMethod: CountRawTemplate,
|
||||||
|
SortedByOrderMethod: SortedByOrderTemplate,
|
||||||
|
SearchByAllStringFields: SearchByAllStringFields,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,11 +16,13 @@ import (
|
|||||||
"github.com/dave/dst/decorator"
|
"github.com/dave/dst/decorator"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ImplementServiceStruct(modelName string, file *dst.File, reimplement bool) {
|
func ImplementServiceStruct(modelName string, file *dst.File, reimplement bool) (wasModified bool) {
|
||||||
serviceName := modelName + "Service"
|
serviceName := modelName + "Service"
|
||||||
isServiceStructDefined := false
|
var (
|
||||||
var insertPos int
|
isServiceStructDefined bool
|
||||||
var decls []dst.Decl
|
insertPos int
|
||||||
|
decls []dst.Decl
|
||||||
|
)
|
||||||
|
|
||||||
for i, decl := range file.Decls {
|
for i, decl := range file.Decls {
|
||||||
genDecl, ok := decl.(*dst.GenDecl)
|
genDecl, ok := decl.(*dst.GenDecl)
|
||||||
@@ -53,7 +55,7 @@ func ImplementServiceStruct(modelName string, file *dst.File, reimplement bool)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if isServiceStructDefined && !reimplement {
|
if isServiceStructDefined && !reimplement {
|
||||||
return
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
serviceStruct := &dst.GenDecl{
|
serviceStruct := &dst.GenDecl{
|
||||||
@@ -69,13 +71,16 @@ func ImplementServiceStruct(modelName string, file *dst.File, reimplement bool)
|
|||||||
}
|
}
|
||||||
|
|
||||||
file.Decls = append(decls[:insertPos], append([]dst.Decl{serviceStruct}, decls[insertPos:]...)...)
|
file.Decls = append(decls[:insertPos], append([]dst.Decl{serviceStruct}, decls[insertPos:]...)...)
|
||||||
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func ImplementModelAlias(modelName string, file *dst.File) {
|
func ImplementModelAlias(modelName string, file *dst.File) (wasModified bool) {
|
||||||
isAliasDefined := false
|
|
||||||
aliasTypeStandard := fmt.Sprintf("models.%s", CapitalizeFirst(modelName))
|
aliasTypeStandard := fmt.Sprintf("models.%s", CapitalizeFirst(modelName))
|
||||||
var insertPos int
|
var (
|
||||||
var decls []dst.Decl
|
insertPos int
|
||||||
|
decls []dst.Decl
|
||||||
|
isAliasDefined bool
|
||||||
|
)
|
||||||
|
|
||||||
for i, decl := range file.Decls {
|
for i, decl := range file.Decls {
|
||||||
genDecl, ok := decl.(*dst.GenDecl)
|
genDecl, ok := decl.(*dst.GenDecl)
|
||||||
@@ -147,7 +152,7 @@ func ImplementModelAlias(modelName string, file *dst.File) {
|
|||||||
Name: &dst.Ident{
|
Name: &dst.Ident{
|
||||||
Name: modelName,
|
Name: modelName,
|
||||||
},
|
},
|
||||||
Assign: true, // quick and dirty
|
Assign: true,
|
||||||
Type: &dst.Ident{
|
Type: &dst.Ident{
|
||||||
Name: aliasTypeStandard,
|
Name: aliasTypeStandard,
|
||||||
},
|
},
|
||||||
@@ -157,6 +162,9 @@ func ImplementModelAlias(modelName string, file *dst.File) {
|
|||||||
|
|
||||||
if !isAliasDefined {
|
if !isAliasDefined {
|
||||||
file.Decls = append(decls[:insertPos], append([]dst.Decl{&typeAlias}, decls[insertPos:]...)...)
|
file.Decls = append(decls[:insertPos], append([]dst.Decl{&typeAlias}, decls[insertPos:]...)...)
|
||||||
|
return true
|
||||||
|
} else {
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -169,8 +177,12 @@ func importExists(file *dst.File, importPath string) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func MaintainImports(file *dst.File) error {
|
func MaintainImports(file *dst.File) (wasModified bool, e error) {
|
||||||
var importDecl *dst.GenDecl
|
var (
|
||||||
|
modified bool
|
||||||
|
importDecl *dst.GenDecl
|
||||||
|
)
|
||||||
|
|
||||||
for _, decl := range file.Decls {
|
for _, decl := range file.Decls {
|
||||||
if genDecl, ok := decl.(*dst.GenDecl); ok && genDecl.Tok == token.IMPORT {
|
if genDecl, ok := decl.(*dst.GenDecl); ok && genDecl.Tok == token.IMPORT {
|
||||||
importDecl = genDecl
|
importDecl = genDecl
|
||||||
@@ -179,6 +191,7 @@ func MaintainImports(file *dst.File) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if importDecl == nil {
|
if importDecl == nil {
|
||||||
|
modified = true
|
||||||
importDecl = &dst.GenDecl{
|
importDecl = &dst.GenDecl{
|
||||||
Tok: token.IMPORT,
|
Tok: token.IMPORT,
|
||||||
Specs: []dst.Spec{},
|
Specs: []dst.Spec{},
|
||||||
@@ -188,6 +201,7 @@ func MaintainImports(file *dst.File) error {
|
|||||||
|
|
||||||
for _, importPath := range ServiceImports {
|
for _, importPath := range ServiceImports {
|
||||||
if !importExists(file, importPath) {
|
if !importExists(file, importPath) {
|
||||||
|
modified = true
|
||||||
importDecl.Specs = append(importDecl.Specs, &dst.ImportSpec{
|
importDecl.Specs = append(importDecl.Specs, &dst.ImportSpec{
|
||||||
Path: &dst.BasicLit{
|
Path: &dst.BasicLit{
|
||||||
Kind: token.STRING,
|
Kind: token.STRING,
|
||||||
@@ -197,7 +211,7 @@ func MaintainImports(file *dst.File) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return modified, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func GenerateCrudMethodCode(methodName string, context CrudTemplatesContext) string {
|
func GenerateCrudMethodCode(methodName string, context CrudTemplatesContext) string {
|
||||||
@@ -237,14 +251,15 @@ func MethodCodeToDeclaration(methodCode string) (*dst.FuncDecl, error) {
|
|||||||
return methodDecl, nil
|
return methodDecl, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func ImplementCrudMethods(modelName string, serviceName string, file *dst.File, reimplement bool) error {
|
func ImplementCrudMethods(modelName string, serviceName string, file *dst.File, reimplement bool) (wasModified bool, e error) {
|
||||||
templateContext := CrudTemplatesContext{
|
templateContext := CrudTemplatesContext{
|
||||||
ServiceName: serviceName,
|
ServiceName: serviceName,
|
||||||
EntityType: modelName,
|
EntityType: modelName,
|
||||||
EntityPlural: ToPlural(modelName),
|
EntityPlural: ToPlural(modelName),
|
||||||
}
|
}
|
||||||
|
modified := reimplement
|
||||||
|
|
||||||
for _, methodName := range []string{CreateMethod, GetAllMethod, GetByIdMethod, UpdateMethod, DeleteMethod, CountMethod} {
|
for _, methodName := range implementedMethods {
|
||||||
methodCode := GenerateCrudMethodCode(methodName, templateContext)
|
methodCode := GenerateCrudMethodCode(methodName, templateContext)
|
||||||
methodDecl, err := MethodCodeToDeclaration(methodCode)
|
methodDecl, err := MethodCodeToDeclaration(methodCode)
|
||||||
fmt.Printf("%s\n", methodCode)
|
fmt.Printf("%s\n", methodCode)
|
||||||
@@ -252,23 +267,27 @@ func ImplementCrudMethods(modelName string, serviceName string, file *dst.File,
|
|||||||
fmt.Println(methodDecl)
|
fmt.Println(methodDecl)
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
err = ImplementMethod(file, methodDecl, reimplement)
|
|
||||||
|
methodModified, err := ImplementMethod(file, methodDecl, reimplement)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return false, err
|
||||||
|
}
|
||||||
|
if methodModified {
|
||||||
|
modified = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return modified, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func ImplementMethod(file *dst.File, methodDecl *dst.FuncDecl, reimplement bool) error {
|
func ImplementMethod(file *dst.File, methodDecl *dst.FuncDecl, reimplement bool) (wasModified bool, e error) {
|
||||||
var decls []dst.Decl
|
var (
|
||||||
methodImplemented := false
|
decls []dst.Decl
|
||||||
|
methodImplemented bool
|
||||||
|
)
|
||||||
|
modified := reimplement
|
||||||
methodStructure := methodDecl.Recv.List[0].Names[0].Name
|
methodStructure := methodDecl.Recv.List[0].Names[0].Name
|
||||||
methodName := methodDecl.Name.Name
|
methodName := methodDecl.Name.Name
|
||||||
log.Printf("Standard method structure: %s\n", methodStructure)
|
|
||||||
log.Printf("Standard method name: %s\n", methodName)
|
|
||||||
|
|
||||||
for _, decl := range file.Decls {
|
for _, decl := range file.Decls {
|
||||||
decls = append(decls, decl)
|
decls = append(decls, decl)
|
||||||
@@ -277,14 +296,14 @@ func ImplementMethod(file *dst.File, methodDecl *dst.FuncDecl, reimplement bool)
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if len(funcDecl.Recv.List) > 0 && len(funcDecl.Recv.List[0].Names) > 0 {
|
if len(funcDecl.Recv.List) > 0 && len(funcDecl.Recv.List[0].Names) > 0 {
|
||||||
fmt.Printf("Method structure: %s\n", funcDecl.Recv.List[0].Names[0].Name)
|
log.Printf("Method structure: %s\n", funcDecl.Recv.List[0].Names[0].Name)
|
||||||
fmt.Printf("Method name: %s\n", funcDecl.Name.Name)
|
log.Printf("Method name: %s\n", funcDecl.Name.Name)
|
||||||
if funcDecl.Recv.List[0].Names[0].Name == methodStructure {
|
if funcDecl.Recv.List[0].Names[0].Name == methodStructure {
|
||||||
if funcDecl.Name != nil && funcDecl.Name.Name == methodName {
|
if funcDecl.Name != nil && funcDecl.Name.Name == methodName {
|
||||||
if methodImplemented {
|
if methodImplemented {
|
||||||
err := fmt.Sprintf("`%s` method redeclarated for struct `%s`", methodName, methodStructure)
|
err := fmt.Sprintf("`%s` method redeclarated for struct `%s`", methodName, methodStructure)
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
return errors.New(err)
|
return false, errors.New(err)
|
||||||
} else {
|
} else {
|
||||||
methodImplemented = true
|
methodImplemented = true
|
||||||
}
|
}
|
||||||
@@ -297,6 +316,7 @@ func ImplementMethod(file *dst.File, methodDecl *dst.FuncDecl, reimplement bool)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if reimplement || !methodImplemented {
|
if reimplement || !methodImplemented {
|
||||||
|
modified = true
|
||||||
file.Decls = append(
|
file.Decls = append(
|
||||||
decls,
|
decls,
|
||||||
&dst.FuncDecl{
|
&dst.FuncDecl{
|
||||||
@@ -310,72 +330,93 @@ func ImplementMethod(file *dst.File, methodDecl *dst.FuncDecl, reimplement bool)
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return modified, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func CreateServiceFileIfNotExists(filePath string) error {
|
func CreateServiceFileIfNotExists(filePath string) (wasModified bool, e error) {
|
||||||
|
var modified bool
|
||||||
if _, err := os.Stat(filePath); err != nil {
|
if _, err := os.Stat(filePath); err != nil {
|
||||||
// file wasn't created
|
// file wasn't created
|
||||||
f, err := os.Create(filePath)
|
f, err := os.Create(filePath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Failed to create file: %s", filePath)
|
log.Fatalf("Failed to create file: %s", filePath)
|
||||||
return err
|
return false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = f.Write([]byte("package services\n"))
|
_, err = f.Write([]byte("package services\n"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Failed to write file: %s", filePath)
|
log.Fatalf("Failed to write file: %s", filePath)
|
||||||
return err
|
return false, err
|
||||||
}
|
}
|
||||||
|
modified = true
|
||||||
|
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
}
|
}
|
||||||
return nil
|
return modified, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func ImplementService(mainPkgPath string, modelName string, reimplement bool) error {
|
func ImplementService(mainPkgPath string, modelName string, reimplement bool) (wasModified bool, e error) {
|
||||||
serviceRelativePath := fmt.Sprintf("services/%s.go", strings.ToLower(modelName))
|
serviceRelativePath := fmt.Sprintf("services/%s.go", strings.ToLower(modelName))
|
||||||
filePath := filepath.Join(mainPkgPath, serviceRelativePath)
|
filePath := filepath.Join(mainPkgPath, serviceRelativePath)
|
||||||
serviceName := modelName + "Service"
|
serviceName := modelName + "Service"
|
||||||
|
modified := reimplement
|
||||||
|
|
||||||
err := CreateServiceFileIfNotExists(filePath)
|
fileModified, err := CreateServiceFileIfNotExists(filePath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return false, err
|
||||||
|
}
|
||||||
|
if fileModified {
|
||||||
|
modified = true
|
||||||
}
|
}
|
||||||
|
|
||||||
fset := token.NewFileSet()
|
fset := token.NewFileSet()
|
||||||
serviceFile, err := decorator.ParseFile(fset, filePath, nil, parser.ParseComments)
|
serviceFile, err := decorator.ParseFile(fset, filePath, nil, parser.ParseComments)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("Parsing error: %s: %v", mainPkgPath, err)
|
log.Fatalf("Parsing error: %s: %v", mainPkgPath, err)
|
||||||
return err
|
return false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = MaintainImports(serviceFile)
|
importsModified, err := MaintainImports(serviceFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return false, err
|
||||||
|
}
|
||||||
|
if importsModified {
|
||||||
|
modified = true
|
||||||
}
|
}
|
||||||
|
|
||||||
ImplementModelAlias(modelName, serviceFile)
|
aliasAdded := ImplementModelAlias(modelName, serviceFile)
|
||||||
ImplementServiceStruct(modelName, serviceFile, reimplement)
|
if aliasAdded {
|
||||||
err = ImplementCrudMethods(modelName, serviceName, serviceFile, reimplement)
|
modified = true
|
||||||
|
}
|
||||||
|
|
||||||
|
serviceStructModified := ImplementServiceStruct(modelName, serviceFile, reimplement)
|
||||||
|
if serviceStructModified {
|
||||||
|
modified = true
|
||||||
|
}
|
||||||
|
|
||||||
|
methodsModified, err := ImplementCrudMethods(modelName, serviceName, serviceFile, reimplement)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return false, err
|
||||||
|
}
|
||||||
|
if methodsModified {
|
||||||
|
modified = true
|
||||||
}
|
}
|
||||||
|
|
||||||
file, err := os.Create(filePath)
|
file, err := os.Create(filePath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.New(fmt.Sprintf("Error occured to open `%s` service file: %v", modelName, err))
|
errMessage := errors.New(fmt.Sprintf("Error occured to open `%s` service file: %v", modelName, err))
|
||||||
|
return false, errMessage
|
||||||
}
|
}
|
||||||
|
|
||||||
err = decorator.Fprint(file, serviceFile)
|
err = decorator.Fprint(file, serviceFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.New(
|
errMessage := errors.New(
|
||||||
fmt.Sprintf("Error occurred to writing changes in `%s` service file: %v", modelName, err),
|
fmt.Sprintf("Error occurred to writing changes in `%s` service file: %v", modelName, err),
|
||||||
)
|
)
|
||||||
|
return false, errMessage
|
||||||
}
|
}
|
||||||
|
|
||||||
defer file.Close()
|
defer file.Close()
|
||||||
|
|
||||||
return nil
|
return modified, nil
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user