mirror of
https://github.com/ManyakRus/crud_generator.git
synced 2025-01-17 08:56:48 +02:00
3056 lines
89 KiB
Go
3056 lines
89 KiB
Go
package create_files
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"github.com/ManyakRus/crud_generator/internal/config"
|
|
"github.com/ManyakRus/crud_generator/internal/constants"
|
|
"github.com/ManyakRus/crud_generator/internal/mini_func"
|
|
"github.com/ManyakRus/crud_generator/internal/types"
|
|
"github.com/ManyakRus/starter/log"
|
|
"github.com/ManyakRus/starter/micro"
|
|
"github.com/iancoleman/strcase"
|
|
"github.com/jinzhu/inflection"
|
|
"sort"
|
|
"strconv"
|
|
"strings"
|
|
)
|
|
|
|
// FindSingularName - возвращает наименование в единственном числе
|
|
func FindSingularName(s string) string {
|
|
var Otvet string
|
|
|
|
if s == "" {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = inflection.Singular(s)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FormatName - возвращает наименование в формате CamelCase
|
|
func FormatName(Name string) string {
|
|
Otvet := Name
|
|
|
|
Otvet1, ok := types.MapReplaceName[Name]
|
|
if ok == true {
|
|
return Otvet1
|
|
}
|
|
|
|
switch strings.ToLower(Name) {
|
|
case "id":
|
|
Otvet = "ID"
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = strcase.ToCamel(Otvet)
|
|
|
|
//_id в конце заменяем на ID
|
|
lenName := len(Name)
|
|
lenOtvet := len(Otvet)
|
|
if lenName >= 3 {
|
|
last3 := strings.ToLower(Name[lenName-3:])
|
|
if last3 == "_id" {
|
|
Otvet = Otvet[:lenOtvet-2] + "ID"
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncFromFuncName - удаляет функцию из текста начиная с объявления функции
|
|
func DeleteFuncFromFuncName(Text, FuncName string) string {
|
|
Otvet := Text
|
|
|
|
TextFind := "\nfunc " + FuncName + "("
|
|
pos1 := strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
s2 := Otvet[pos1+1:]
|
|
|
|
posEnd := strings.Index(s2, "\n}")
|
|
if posEnd < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1-1] + Otvet[pos1+posEnd+3:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncFromComment - удаляет функцию из текста начиная с комментария
|
|
func DeleteFuncFromComment(Text, Comment string) string {
|
|
Otvet := Text
|
|
|
|
TextFind := Comment
|
|
pos1 := strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
s2 := Otvet[pos1+1:]
|
|
|
|
posEnd := strings.Index(s2, "\n}")
|
|
if posEnd < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1-1] + Otvet[pos1+posEnd+3:]
|
|
|
|
return Otvet
|
|
|
|
}
|
|
|
|
// DeleteCommentFromFuncName - удаляет комментарий с названием функции
|
|
func DeleteCommentFromFuncName(Text, FuncName string) string {
|
|
Otvet := Text
|
|
|
|
TextFind := "//" + FuncName + "()"
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, "")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteLineWithComment - удаляет текст от комментария до конца строки
|
|
func DeleteLineWithComment(Text, FuncName string) string {
|
|
Otvet := Text
|
|
|
|
TextFind := "//" + FuncName + "()"
|
|
pos1 := strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
s2 := Otvet[pos1:]
|
|
|
|
posEnd := strings.Index(s2, "\n")
|
|
if posEnd < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1-1] + Otvet[pos1+posEnd+1:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindPrimaryKeyNameTypeGo - возвращает наименование и тип golang колонки PrimaryKey
|
|
func FindPrimaryKeyNameTypeGo(Table1 *types.Table) (string, string) {
|
|
Otvet := ""
|
|
Type := ""
|
|
|
|
//сортировка по названию колонок
|
|
keys := make([]string, 0, len(Table1.MapColumns))
|
|
for k := range Table1.MapColumns {
|
|
keys = append(keys, k)
|
|
}
|
|
sort.Strings(keys)
|
|
|
|
for _, key1 := range keys {
|
|
Column1, ok := Table1.MapColumns[key1]
|
|
if ok == false {
|
|
log.Panic("Table1.MapColumns[key1] = false")
|
|
}
|
|
if Column1.IsPrimaryKey == true {
|
|
return Column1.NameGo, Column1.TypeGo
|
|
}
|
|
}
|
|
|
|
return Otvet, Type
|
|
}
|
|
|
|
// FindPrimaryKeyNameType - возвращает наименование и тип БД колонки PrimaryKey
|
|
func FindPrimaryKeyNameType(Table1 *types.Table) (string, string) {
|
|
Otvet := ""
|
|
Type := ""
|
|
|
|
//сортировка по названию колонок
|
|
keys := make([]string, 0, len(Table1.MapColumns))
|
|
for k := range Table1.MapColumns {
|
|
keys = append(keys, k)
|
|
}
|
|
sort.Strings(keys)
|
|
|
|
for _, key1 := range keys {
|
|
Column1, ok := Table1.MapColumns[key1]
|
|
if ok == false {
|
|
log.Panic("Table1.MapColumns[key1] = false")
|
|
}
|
|
if Column1.IsPrimaryKey == true {
|
|
return Column1.Name, Column1.Type
|
|
}
|
|
}
|
|
|
|
return Otvet, Type
|
|
}
|
|
|
|
// FindPrimaryKeyColumn - возвращает Column для колонки PrimaryKey
|
|
func FindPrimaryKeyColumn(Table1 *types.Table) (Column1 *types.Column) {
|
|
var Otvet *types.Column
|
|
|
|
//сортировка по названию колонок
|
|
keys := make([]string, 0, len(Table1.MapColumns))
|
|
for k := range Table1.MapColumns {
|
|
keys = append(keys, k)
|
|
}
|
|
sort.Strings(keys)
|
|
|
|
for _, key1 := range keys {
|
|
Column1, ok := Table1.MapColumns[key1]
|
|
if ok == false {
|
|
log.Panic("Table1.MapColumns[key1] = false")
|
|
}
|
|
if Column1.IsPrimaryKey == true {
|
|
return Column1
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindPrimaryKeyColumns - возвращает несколько Column для колонки PrimaryKey
|
|
func FindPrimaryKeyColumns(Table1 *types.Table) []*types.Column {
|
|
Otvet := make([]*types.Column, 0)
|
|
|
|
//сортировка по названию колонок
|
|
keys := make([]string, 0, len(Table1.MapColumns))
|
|
for k := range Table1.MapColumns {
|
|
keys = append(keys, k)
|
|
}
|
|
sort.Strings(keys)
|
|
|
|
for _, key1 := range keys {
|
|
Column1, ok := Table1.MapColumns[key1]
|
|
if ok == false {
|
|
log.Panic("Table1.MapColumns[key1] = false")
|
|
}
|
|
if Column1.IsPrimaryKey == true {
|
|
Otvet = append(Otvet, Column1)
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
//// FindPrimaryKeyNameTypeGo - возвращает наименование и тип golang колонки PrimaryKey
|
|
//func FindPrimaryKeyNameTypeGo(Table1 *types.Table) (string, string) {
|
|
// Otvet := ""
|
|
// Type := ""
|
|
//
|
|
// for _, Column1 := range Table1.MapColumns {
|
|
// if Column1.IsIdentity == true {
|
|
// return Column1.NameGo, Column1.TypeGo
|
|
// }
|
|
// }
|
|
//
|
|
// return Otvet, Type
|
|
//}
|
|
|
|
// ReplacePrimaryKeyOtvetID - заменяет "Otvet.ID" на название колонки PrimaryKey
|
|
func ReplacePrimaryKeyOtvetID(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//PrimaryKeyCount := Table1.PrimaryKeyColumnsCount
|
|
//if PrimaryKeyCount == 1 {
|
|
// Otvet = ReplacePrimaryKeyOtvetID1(Otvet, Table1)
|
|
//} else {
|
|
Otvet = ReplacePrimaryKeyOtvetID_Many(Otvet, Table1)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextEqual0 - возвращает текст сравнения с нулевым значением
|
|
func FindTextEqual0(Column1 *types.Column) string {
|
|
Otvet := " == 0"
|
|
|
|
switch Column1.TypeGo {
|
|
case "string":
|
|
Otvet = ` == ""`
|
|
case "uuid.UUID":
|
|
Otvet = ` == uuid.Nil`
|
|
case "time.Time":
|
|
Otvet = `.IsZero() == true`
|
|
case "bool":
|
|
Otvet = ` == false`
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplacePrimaryKeyOtvetID1 - заменяет "Otvet.ID" на название колонки PrimaryKey
|
|
func ReplacePrimaryKeyOtvetID1(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
ColumnNamePK, ColumnTypeGoPK := FindPrimaryKeyNameTypeGo(Table1)
|
|
ColumnPK := FindPrimaryKeyColumn(Table1)
|
|
|
|
//заменим ID-Alias на ID
|
|
TableName := Table1.Name
|
|
IDName, _ := FindPrimaryKeyNameType(Table1)
|
|
Alias, ok := types.MapConvertID[TableName+"."+IDName]
|
|
OtvetColumnName := "Otvet." + ColumnNamePK
|
|
if ok == true {
|
|
OtvetColumnName = Alias + "(" + OtvetColumnName + ")"
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "Otvet.ID = AliasFromInt(ID)", "Otvet."+ColumnNamePK+" = "+ColumnNamePK)
|
|
|
|
//заменим int64(Otvet.ID) на Otvet.ID
|
|
if mini_func.IsNumberType(ColumnTypeGoPK) == true {
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID)", OtvetColumnName)
|
|
} else if ColumnTypeGoPK == "string" {
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID) == 0", OtvetColumnName+" == \"\"")
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID) != 0", OtvetColumnName+" != \"\"")
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID)", OtvetColumnName)
|
|
} else if ColumnTypeGoPK == "uuid.UUID" || ColumnTypeGoPK == "uuid.NullUUID" {
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID) == 0", OtvetColumnName+" == uuid.Nil")
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID) != 0", OtvetColumnName+" != uuid.Nil")
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID)", OtvetColumnName)
|
|
} else if ColumnTypeGoPK == "time.Time" {
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID) == 0", OtvetColumnName+".IsZero() == true")
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID) != 0", OtvetColumnName+".IsZero() == false")
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(Otvet.ID)", OtvetColumnName)
|
|
}
|
|
//Otvet = strings.ReplaceAll(Otvet, "Otvet.ID = ", OtvetColumnName+" = ")
|
|
//Otvet = strings.ReplaceAll(Otvet, "Otvet.ID != ", OtvetColumnName+" != ")
|
|
//Otvet = strings.ReplaceAll(Otvet, " Otvet.ID)", " "+OtvetColumnName+")")
|
|
Otvet = strings.ReplaceAll(Otvet, " Otvet.ID)", " Otvet."+ColumnNamePK+")")
|
|
|
|
//Alias преобразуем в int64, и наоборот
|
|
if Alias != "" {
|
|
Otvet = strings.ReplaceAll(Otvet, "IntFromAlias(Otvet.ID)", ColumnTypeGoPK+"(Otvet."+ColumnNamePK+")")
|
|
Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(Otvet.ID)", OtvetColumnName)
|
|
Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(ID)", Alias+"("+ColumnNamePK+")")
|
|
} else {
|
|
Otvet = strings.ReplaceAll(Otvet, "IntFromAlias(Otvet.ID)", "Otvet."+ColumnNamePK+"")
|
|
Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(Otvet.ID)", OtvetColumnName)
|
|
Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(ID)", "ID")
|
|
}
|
|
|
|
Value, GolangCode := ConvertProtobufVariableToGolangVariable(Table1, ColumnPK, "Request.")
|
|
if GolangCode == "" {
|
|
TextNew := "\t" + ColumnPK.NameGo + " := " + Value + "\n"
|
|
Otvet = strings.ReplaceAll(Otvet, "\tID := Request.ID\n", TextNew)
|
|
} else {
|
|
TextNew := "\t" + GolangCode + "\n"
|
|
Otvet = strings.ReplaceAll(Otvet, "\tID := Request.ID\n", TextNew)
|
|
}
|
|
|
|
Value, GolangCode = ConvertProtobufTypeToGolangAlias(Table1, ColumnPK, "Request.")
|
|
if GolangCode == "" {
|
|
TextNew := "\t" + ColumnPK.NameGo + " := " + Value + "\n"
|
|
Otvet = strings.ReplaceAll(Otvet, "\tID := AliasFromProto(Request.ID)\n", TextNew)
|
|
} else {
|
|
TextNew := "\t" + GolangCode + "\n"
|
|
Otvet = strings.ReplaceAll(Otvet, "\tID := AliasFromProto(Request.ID)\n", TextNew)
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplacePrimaryKeyOtvetID_Many - заменяет "Otvet.ID" на название колонки PrimaryKey
|
|
func ReplacePrimaryKeyOtvetID_Many(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
Otvet = ReplacePrimaryKeyOtvetID_ManyPK1(Otvet, Table1, "Otvet")
|
|
Otvet = ReplacePrimaryKeyOtvetID_ManyPK1(Otvet, Table1, "Request")
|
|
Otvet = ReplacePrimaryKeyOtvetID_ManyPK1(Otvet, Table1, "m")
|
|
|
|
Otvet = ReplacePrimaryKeyOtvetID1(Otvet, Table1) //для тестов
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplacePrimaryKeyOtvetID_ManyPK1 - заменяет "Otvet.ID" на название колонки PrimaryKey
|
|
func ReplacePrimaryKeyOtvetID_ManyPK1(Text string, Table1 *types.Table, VariableName string) string {
|
|
Otvet := Text
|
|
|
|
//сортировка по названию таблиц
|
|
keys := make([]string, 0, len(Table1.MapColumns))
|
|
for k := range Table1.MapColumns {
|
|
keys = append(keys, k)
|
|
}
|
|
sort.Strings(keys)
|
|
|
|
TextOtvetIDAliasID := ""
|
|
TextIfMId := ""
|
|
TextIfMIdNot0 := ""
|
|
TextM2ID := ""
|
|
TextIDRequestID := ""
|
|
TextOtvetIDID := ""
|
|
TextRequestIDmID := ""
|
|
TextRequestIDInt64ID := ""
|
|
TextOtvetIDmID := ""
|
|
TextMID0 := ""
|
|
TextOR := ""
|
|
for _, key1 := range keys {
|
|
Column1, _ := Table1.MapColumns[key1]
|
|
if Column1.IsPrimaryKey != true {
|
|
continue
|
|
}
|
|
TextOtvetIDID = TextOtvetIDID + "\t" + VariableName + "." + Column1.NameGo + " = " + Column1.NameGo + "\n"
|
|
RequestColumnName := FindRequestFieldName(Table1, Column1)
|
|
Value, GolangCode := ConvertProtobufVariableToGolangVariable(Table1, Column1, "Request.")
|
|
if GolangCode == "" {
|
|
TextIDRequestID = TextIDRequestID + "\t" + Column1.NameGo + " := " + Value + "\n"
|
|
} else {
|
|
TextIDRequestID = TextIDRequestID + "\t" + GolangCode + "\n"
|
|
}
|
|
TextM := ConvertGolangVariableToProtobufVariable(Column1, "m")
|
|
TextRequestIDmID = TextRequestIDmID + "\t" + VariableName + "." + RequestColumnName + " = " + TextM + "\n"
|
|
TextInt64ID := ConvertGolangVariableToProtobufVariable(Column1, "")
|
|
TextRequestIDInt64ID = TextRequestIDInt64ID + "\t" + VariableName + "." + RequestColumnName + " = " + TextInt64ID + "\n"
|
|
TextOtvetIDmID = TextOtvetIDmID + "\t" + "Otvet." + Column1.NameGo + " = " + VariableName + "." + Column1.NameGo + "\n"
|
|
|
|
DefaultValue := FindTextDefaultValue(Column1.TypeGo)
|
|
|
|
TextM2ID = TextM2ID + "\t" + "m2." + Column1.NameGo + " = " + "m." + Column1.NameGo + "\n"
|
|
TextIfMId = TextIfMId + TextOR + "m." + Column1.NameGo + " == " + DefaultValue
|
|
TextIfMIdNot0 = TextIfMIdNot0 + TextOR + "m." + Column1.NameGo + " != " + DefaultValue
|
|
|
|
TextMID0 = TextMID0 + TextOR + " (" + VariableName + "." + Column1.NameGo + " == " + DefaultValue + ")"
|
|
TextAlias := ConvertIDToAlias(Table1, Column1, Column1.NameGo)
|
|
TextOtvetIDAliasID = TextOtvetIDAliasID + "\t" + VariableName + "." + Column1.NameGo + " = " + TextAlias + "\n"
|
|
TextOR = " || "
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "\t"+VariableName+".ID = AliasFromInt(ID)", TextOtvetIDAliasID)
|
|
//Otvet = strings.ReplaceAll(Otvet, "\t"+VariableName+".ID = AliasFromInt(ID)", TextOtvetIDID)
|
|
Otvet = strings.ReplaceAll(Otvet, "\t"+VariableName+".ID = ProtoFromInt(m.ID)", TextRequestIDmID)
|
|
Otvet = strings.ReplaceAll(Otvet, "\t"+VariableName+".ID = int64(ID)", TextRequestIDInt64ID)
|
|
Otvet = strings.ReplaceAll(Otvet, "\tOtvet.ID = "+VariableName+".ID\n", TextOtvetIDmID)
|
|
Otvet = strings.ReplaceAll(Otvet, " IntFromAlias("+VariableName+".ID) == 0", TextMID0)
|
|
Otvet = strings.ReplaceAll(Otvet, "\tm2.ID = int64(m.ID)", TextM2ID)
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) == 0", TextIfMId)
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) != 0", TextIfMIdNot0)
|
|
//Value := ConvertGolangVariableToProtobufVariable(Table1, ColumnPK, "m")
|
|
//Otvet = strings.ReplaceAll(Otvet, "ProtoFromInt(m.ID)", Value) //protobuf
|
|
|
|
//заменим ID := Request.ID
|
|
Otvet = strings.ReplaceAll(Otvet, "\tID := Request.ID\n", TextIDRequestID)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplacePrimaryKeyM_ID - заменяет "m.ID" на название колонки PrimaryKey
|
|
func ReplacePrimaryKeyM_ID(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//PrimaryKeyCount := Table1.PrimaryKeyColumnsCount
|
|
//if PrimaryKeyCount == 1 {
|
|
// Otvet = ReplacePrimaryKeyM_ID1(Otvet, Table1)
|
|
//} else {
|
|
Otvet = ReplacePrimaryKeyM_ManyPK(Otvet, Table1)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplacePrimaryKeyM_ManyPK - заменяет "m.ID" на название колонки PrimaryKey
|
|
func ReplacePrimaryKeyM_ManyPK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
Otvet = ReplacePrimaryKeyOtvetID_ManyPK1(Otvet, Table1, "m")
|
|
Otvet = ReplacePrimaryKeyOtvetID_ManyPK1(Otvet, Table1, "Request")
|
|
|
|
//заменим int64(m.ID)
|
|
//Otvet = ReplacePrimaryKeyM_ID1(Otvet, Table1)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
//// ReplacePrimaryKeyM_ID1 - заменяет "m.ID" на название колонки PrimaryKey
|
|
//func ReplacePrimaryKeyM_ID1(Text string, Table1 *types.Table) string {
|
|
// Otvet := Text
|
|
//
|
|
// ColumnNamePK, ColumnTypeGoPK := FindPrimaryKeyNameTypeGo(Table1)
|
|
// ColumnPK := FindPrimaryKeyColumn(Table1)
|
|
//
|
|
// //заменим ID-Alias на ID
|
|
// TableName := Table1.Name
|
|
// IDName, _ := FindPrimaryKeyNameType(Table1)
|
|
// Alias, _ := types.MapConvertID[TableName+"."+IDName]
|
|
// OtvetColumnName := "m." + ColumnNamePK
|
|
// //if ok == true {
|
|
// // OtvetColumnName = Alias + "(" + OtvetColumnName + ")"
|
|
// //}
|
|
//
|
|
// //заменим int64(m.ID) на m.ID
|
|
// if mini_func.IsNumberType(ColumnTypeGoPK) == true {
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID)", OtvetColumnName)
|
|
// } else if ColumnTypeGoPK == "string" {
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) == 0", OtvetColumnName+" == \"\"")
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) != 0", OtvetColumnName+" != \"\"")
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID)", OtvetColumnName)
|
|
// } else if ColumnTypeGoPK == "uuid.UUID" || ColumnTypeGoPK == "uuid.NullUUID" {
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) == 0", OtvetColumnName+" == uuid.Nil")
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) != 0", OtvetColumnName+" != uuid.Nil")
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID)", OtvetColumnName+".String()")
|
|
// } else if ColumnTypeGoPK == "time.Time" {
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) == 0", OtvetColumnName+".IsZero() == true")
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID) != 0", OtvetColumnName+".IsZero() == false")
|
|
// Otvet = strings.ReplaceAll(Otvet, "int64(m.ID)", OtvetColumnName)
|
|
// }
|
|
// //Otvet = strings.ReplaceAll(Otvet, "m.ID = ", OtvetColumnName+" = ")
|
|
// //Otvet = strings.ReplaceAll(Otvet, " = m.ID", " = "+OtvetColumnName)
|
|
// Otvet = strings.ReplaceAll(Otvet, ", m.ID,", ", "+OtvetColumnName+",")
|
|
// //Otvet = strings.ReplaceAll(Otvet, "(m.ID)", "("+OtvetColumnName+")")
|
|
// Value := ConvertColumnToAlias(Table1, ColumnPK, "")
|
|
// Otvet = strings.ReplaceAll(Otvet, "m.ID = AliasFromInt(ID)", "m."+ColumnNamePK+" = "+Value)
|
|
//
|
|
// Otvet = strings.ReplaceAll(Otvet, "\tm2.ID = ", "\tm2."+ColumnNamePK+" = ")
|
|
//
|
|
// //Alias преобразуем в int64, и наоборот
|
|
// if Alias != "" {
|
|
// Otvet = strings.ReplaceAll(Otvet, "IntFromAlias(m.ID)", ColumnTypeGoPK+"(m."+ColumnNamePK+")")
|
|
// Otvet = strings.ReplaceAll(Otvet, "IntFromAlias(m.ID)", ColumnTypeGoPK+"(m."+ColumnNamePK+")")
|
|
// Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(m.ID)", OtvetColumnName)
|
|
// Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(ID)", Alias+"("+ColumnNamePK+")")
|
|
// Value := ConvertGolangVariableToProtobufVariable(Table1, ColumnPK, "m")
|
|
// Otvet = strings.ReplaceAll(Otvet, "ProtoFromInt(m.ID)", Value) //protobuf
|
|
// } else {
|
|
// DefaultValue := FindTextDefaultValue(ColumnTypeGoPK)
|
|
// Otvet = strings.ReplaceAll(Otvet, "IntFromAlias(m.ID) == 0", "m."+ColumnNamePK+" == "+DefaultValue)
|
|
// //Value := ConvertGolangVariableToProtobufVariable(Table1, ColumnPK, "m")
|
|
// Otvet = strings.ReplaceAll(Otvet, "IntFromAlias(m.ID)", "m."+ColumnNamePK) //не protobuf
|
|
// Value := ConvertGolangVariableToProtobufVariable(Table1, ColumnPK, "m")
|
|
// Otvet = strings.ReplaceAll(Otvet, "ProtoFromInt(m.ID)", Value) //protobuf
|
|
// Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(m.ID)", OtvetColumnName)
|
|
// Otvet = strings.ReplaceAll(Otvet, "AliasFromInt(ID)", "ID")
|
|
// Otvet = strings.ReplaceAll(Otvet, " ID=0", " "+ColumnNamePK+"="+DefaultValue)
|
|
// Otvet = strings.ReplaceAll(Otvet, "(m.ID)", "(m."+ColumnNamePK+")")
|
|
// }
|
|
//
|
|
// return Otvet
|
|
//}
|
|
|
|
// ReplaceColumnNamePK - заменяет "ColumnNamePK" на текст имя колонки
|
|
func ReplaceColumnNamePK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
ColumnPK := FindPrimaryKeyColumn(Table1)
|
|
Otvet = strings.ReplaceAll(Otvet, "ColumnNamePK", ColumnPK.NameGo)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceIntFromAlias - заменяет "m.ID" на текст m.ID или int64(m.ID)
|
|
func ReplaceIntFromAlias(Text string, Table1 *types.Table, Column1 *types.Column, VariableName string) string {
|
|
Otvet := Text
|
|
|
|
Value := ConvertFromAlias(Table1, Column1, VariableName)
|
|
Otvet = strings.ReplaceAll(Otvet, "IntFromAlias("+VariableName+".ID)", Value)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertFromAlias - возвращает текст m.ID или int64(m.ID)
|
|
func ConvertFromAlias(Table1 *types.Table, Column1 *types.Column, VariableName string) string {
|
|
Otvet := VariableName + "." + Column1.NameGo
|
|
|
|
TextConvert, ok := types.MapConvertID[Table1.Name+"."+Column1.Name]
|
|
if ok == false {
|
|
return Otvet
|
|
}
|
|
|
|
if TextConvert[:6] != "alias." {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Column1.TypeGo + "(" + VariableName + "." + Column1.NameGo + ")"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddSkipNow - добавляет строку t.SkipNow()
|
|
func AddSkipNow(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
Columns := FindPrimaryKeyColumns(Table1)
|
|
if Columns == nil {
|
|
return Otvet
|
|
}
|
|
|
|
//проверка ИД=""
|
|
is_no_zero := true
|
|
for _, Column1 := range Columns {
|
|
if Column1.IDMinimum == "" || Column1.IDMinimum == "0" {
|
|
is_no_zero = false
|
|
break
|
|
}
|
|
}
|
|
|
|
//если нет пустых то возврат
|
|
if is_no_zero == true {
|
|
return Otvet
|
|
}
|
|
|
|
//добавляем t.SkipNow()
|
|
TextFind := "(t *testing.T) {"
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextFind+"\n\tt.SkipNow() //now rows in DB\n")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// IsGoodTable - возвращает ошибку если таблица неправильная
|
|
func IsGoodTable(Table1 *types.Table) error {
|
|
var err error
|
|
|
|
err = IsGoodTableNamePrefix(Table1)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
err = IsGoodPrimaryKeyColumnsCount(Table1)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
// IsGoodPrimaryKeyColumnsCount - возвращает ошибку если количество колонок PrimaryKey неправильное
|
|
func IsGoodPrimaryKeyColumnsCount(Table1 *types.Table) error {
|
|
var err error
|
|
|
|
if Table1.PrimaryKeyColumnsCount <= 0 {
|
|
TextError := fmt.Sprint("Wrong table: ", Table1.Name, " error: can not use many Primary key columns count: ", Table1.PrimaryKeyColumnsCount)
|
|
err = errors.New(TextError)
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
// IsGoodTableNamePrefix - возвращает ошибку если префикс таблицы = "DELETED_"
|
|
func IsGoodTableNamePrefix(Table1 *types.Table) error {
|
|
var err error
|
|
|
|
TableName := Table1.Name
|
|
if strings.HasPrefix(TableName, "DELETED_") == true {
|
|
TextError := fmt.Sprint("Wrong table: ", Table1.Name, " error: name = DELETED_")
|
|
err = errors.New(TextError)
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
// PrintableString - возвращает строку без запрещённых символов
|
|
func PrintableString(s string) string {
|
|
Otvet := s
|
|
Otvet = strconv.Quote(Otvet) //экранирование символов
|
|
len1 := len(Otvet)
|
|
if len1 > 0 {
|
|
Otvet = Otvet[1 : len1-1]
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Find_Template_DB_Foldername - возвращает путь к папке
|
|
func Find_Template_DB_Foldername() string {
|
|
Otvet := ""
|
|
|
|
DirBin := micro.ProgramDir_bin()
|
|
DirTemplates := DirBin + config.Settings.TEMPLATE_FOLDERNAME + micro.SeparatorFile()
|
|
DirTemplatesDB := DirTemplates + config.Settings.TEMPLATE_FOLDERNAME_CRUD + micro.SeparatorFile()
|
|
|
|
Otvet = DirTemplatesDB
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteImportModel - удаляет лишний импорт модели
|
|
func DeleteImportModel(s string) string {
|
|
Otvet := s
|
|
|
|
ModelURL := FindModelURL()
|
|
ImportName := micro.LastWord(ModelURL)
|
|
|
|
pos1 := strings.Index(Otvet, ImportName+".")
|
|
if pos1 < 0 {
|
|
Otvet = strings.ReplaceAll(Otvet, `"`+ModelURL+`"\n`, "")
|
|
Otvet = strings.ReplaceAll(Otvet, `"`+ModelURL+`"`, "")
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindModelURL - возвращает URL репозитория с пакетом "model"
|
|
func FindModelURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_MODEL
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindGRPCServerURL - возвращает URL репозитория с пакетом "server_grpc"
|
|
func FindGRPCServerURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_GRPC_SERVER
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindGRPCClientURL - возвращает URL репозитория с пакетом "client_grpc"
|
|
func FindGRPClientURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_GRPC_CLIENT
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindNRPClientURL - возвращает URL репозитория с пакетом "client_nrpc"
|
|
func FindNRPClientURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_NRPC_CLIENT
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindGRPCConstantsURL - возвращает URL репозитория с пакетом "client_grpc"
|
|
func FindGRPCConstantsURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_GRPC + "/" + "grpc_constants"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindNRPCServerlURL - возвращает URL репозитория с пакетом "server_nrpc"
|
|
func FindNRPCServerlURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_NRPC_SERVER
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindProtobufURL - возвращает URL репозитория с файлом .proto
|
|
func FindProtobufURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_GRPC_PROTO
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTablesURL - возвращает URL репозитория с пакетом "tables"
|
|
func FindTablesURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_TABLES
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTableNameURL - возвращает URL репозитория с пакетом "tables" + TableName
|
|
func FindTableNameURL(TableName string) string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_TABLES + "/" + config.Settings.PREFIX_TABLE + TableName
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindProtoURL - возвращает URL репозитория с пакетом "grpc_proto"
|
|
func FindProtoURL() string {
|
|
Otvet := ""
|
|
|
|
TEMPLATE_FOLDERNAME_GRPC_PROTO := strings.ToLower(config.Settings.TEMPLATE_FOLDERNAME_GRPC_PROTO)
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + TEMPLATE_FOLDERNAME_GRPC_PROTO + "/" + "grpc_proto"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindModelTableURL - возвращает URL репозитория model для таблицы TableName
|
|
func FindModelTableURL(TableName string) string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_MODEL + "/" + TableName
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindCrudStarterTableURL - возвращает URL репозитория crud_starter для таблицы TableName
|
|
func FindCrudStarterTableURL(TableName string) string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_CRUD_STARTER + "/" + constants.STARTER_TABLES_PREFIX + TableName
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindCrudTableURL - возвращает URL репозитория crud для таблицы TableName
|
|
func FindCrudTableURL(TableName string) string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_CRUD + "/" + constants.CRUD_TABLES_FREFIX + TableName
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindNRPC_Client_URL - возвращает URL репозитория с пакетом "nrpc_client"
|
|
func FindNRPC_Client_URL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_NRPC_CLIENT
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindDBConstantsURL - возвращает URL репозитория с пакетом db "db_constants"
|
|
func FindDBConstantsURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_DB + "/" + "db_constants"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindConstantsURL - возвращает URL репозитория с пакетом pkg "constants"
|
|
func FindConstantsURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_CONSTANTS
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindNRPCConstantsURL - возвращает URL репозитория с пакетом db "constants"
|
|
func FindNRPCConstantsURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_NRPC + "/" + "nrpc_constants"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindCrudStarterURL - возвращает URL репозитория с пакетом "crud_starter"
|
|
func FindCrudStarterURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_CRUD_STARTER
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Find_GRPC_NRPC_URL - возвращает URL репозитория с пакетом "crud_starter"
|
|
func Find_GRPC_NRPC_URL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_GRPC_NRPC
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Find_grpc_client_func_URL - возвращает URL репозитория с пакетом "grpc_client_func"
|
|
func Find_grpc_client_func_URL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_GRPC_CLIENT_FUNC
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindCalcStructVersionURL - возвращает URL репозитория с пакетом "calc_struct_version"
|
|
func FindCalcStructVersionURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDERNAME_DB + "/" + "calc_struct_version"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindCrudFunctionsURL - возвращает URL репозитория с пакетом crud_functions
|
|
func FindCrudFunctionsURL() string {
|
|
Otvet := ""
|
|
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/" + config.Settings.TEMPLATE_FOLDER_CRUD_FUNCTIONS
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextDefaultGORMValue - возвращает значение по умолчанию для столбца Column1 для тегов в GORM
|
|
func FindTextDefaultGORMValue(Column1 *types.Column) string {
|
|
var Otvet string
|
|
|
|
ColumnName := Column1.Name
|
|
|
|
//ищем в файле настроек nullable.json
|
|
is_nullable_config, _ := types.MapNullableFileds[ColumnName]
|
|
|
|
//
|
|
sValue := ""
|
|
Type_go := Column1.TypeGo
|
|
// if Column1.TableKey != "" && Column1.IsNullable == true && (is_nullable_config == true || has_is_nullable_config == false) {
|
|
if Column1.IsNullable == true || (is_nullable_config == true) {
|
|
sValue = "null"
|
|
} else {
|
|
|
|
switch Type_go {
|
|
case "string":
|
|
sValue = "\\\"\\\""
|
|
case "int", "int32", "int64", "float32", "float64", "uint", "uint32", "uint64":
|
|
sValue = "0"
|
|
case "time.Time":
|
|
sValue = "null"
|
|
case "uuid.UUID", "uuid.NullUUID":
|
|
sValue = "null"
|
|
}
|
|
}
|
|
|
|
if sValue != "" {
|
|
Otvet = ";default:" + sValue
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextDefaultValue - возвращает golang значение по умолчанию для типа
|
|
func FindTextDefaultValue(Type_go string) string {
|
|
var Otvet string
|
|
|
|
switch Type_go {
|
|
case "string":
|
|
Otvet = `""`
|
|
case "int", "int32", "int64", "float32", "float64", "uint", "uint32", "uint64":
|
|
Otvet = "0"
|
|
case "time.Time":
|
|
Otvet = "time.Time{}"
|
|
case "bool":
|
|
Otvet = "false"
|
|
case "uuid.UUID", "uuid.NullUUID":
|
|
Otvet = "uuid.Nil"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextDefaultValueSQL - возвращает значение по умолчанию для типа
|
|
func FindTextDefaultValueSQL(Type_go string) string {
|
|
var Otvet string
|
|
|
|
switch Type_go {
|
|
case "string":
|
|
Otvet = `''`
|
|
case "int", "int32", "int64", "float32", "float64", "uint", "uint32", "uint64":
|
|
Otvet = "0"
|
|
case "time.Time":
|
|
Otvet = "null"
|
|
case "bool":
|
|
Otvet = "false"
|
|
case "uuid.UUID", "uuid.NullUUID":
|
|
Otvet = "null"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindURL_Alias - возвращает URL репозитория с пакетом "alias"
|
|
func FindURL_Alias() string {
|
|
Otvet := ""
|
|
if config.Settings.TEMPLATE_FOLDERNAME_ALIAS == "" {
|
|
return Otvet
|
|
}
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/"
|
|
Otvet = Otvet + config.Settings.TEMPLATE_FOLDERNAME_ALIAS
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindURL_Tables - возвращает URL репозитория с пакетом "tables"
|
|
func FindURL_Tables() string {
|
|
Otvet := ""
|
|
Otvet = config.Settings.SERVICE_REPOSITORY_URL + "/"
|
|
Otvet = Otvet + config.Settings.TEMPLATE_FOLDERNAME_TABLES
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddImport - добавляет RepositoryURL в секцию Import, если его там нет
|
|
func AddImport(Text, RepositoryURL string) string {
|
|
Otvet := Text
|
|
|
|
//если уже есть импорт
|
|
pos1 := strings.Index(Otvet, `"`+RepositoryURL+`"`)
|
|
if pos1 >= 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//
|
|
TextFind := "import ("
|
|
LenFind := len(TextFind)
|
|
pos1 = strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
log.Error("not found word: import (")
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1+LenFind] + "\n\t" + `"` + RepositoryURL + `"` + Otvet[pos1+LenFind:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImport - добавляет URL в секцию Import, если его там нет, если он нужен
|
|
func CheckAndAddImport(Text, URL string) string {
|
|
Otvet := Text
|
|
|
|
//проверим используется или нет
|
|
ModuleName := micro.LastWord(URL)
|
|
pos1 := strings.Index(Otvet, ModuleName+".")
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = AddImport(Text, URL)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddImportTime - добавляет пакет в секцию Import, если его там нет
|
|
func AddImportTime(Text string) string {
|
|
Otvet := Text
|
|
|
|
RepositoryURL := `time`
|
|
Otvet = AddImport(Text, RepositoryURL)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportStrconv - добавляет пакет в секцию Import, если его там нет
|
|
func CheckAndAddImportStrconv(Text string) string {
|
|
Otvet := Text
|
|
|
|
RepositoryURL := `strconv`
|
|
Otvet = CheckAndAddImport(Text, RepositoryURL)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportFmt - добавляет пакет fmt в секцию Import, если его там нет
|
|
func CheckAndAddImportFmt(Text string) string {
|
|
Otvet := Text
|
|
|
|
RepositoryURL := `fmt`
|
|
Otvet = CheckAndAddImport(Text, RepositoryURL)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddImportUUID - добавляет пакет в секцию Import, если его там нет
|
|
func AddImportUUID(Text string) string {
|
|
Otvet := Text
|
|
|
|
//если уже есть импорт
|
|
RepositoryURL := `github.com/google/uuid`
|
|
Otvet = AddImport(Text, RepositoryURL)
|
|
//pos1 := strings.Index(Otvet, RepositoryURL)
|
|
//if pos1 >= 0 {
|
|
// return Otvet
|
|
//}
|
|
//
|
|
////
|
|
//TextImport := "import ("
|
|
//pos1 = strings.Index(Otvet, TextImport)
|
|
//if pos1 < 0 {
|
|
// log.Error("not found word: ", TextImport)
|
|
// return TextModel
|
|
//}
|
|
//
|
|
//Otvet = Otvet[:pos1+len(TextImport)] + "\n\t" + RepositoryURL + Otvet[pos1+len(TextImport):]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddImportGorm - добавляет пакет в секцию Import, если его там нет
|
|
func AddImportGorm(Text string) string {
|
|
Otvet := Text
|
|
|
|
//если уже есть импорт
|
|
RepositoryURL := `gorm.io/gorm`
|
|
Otvet = AddImport(Text, RepositoryURL)
|
|
//pos1 := strings.Index(Otvet, RepositoryURL)
|
|
//if pos1 >= 0 {
|
|
// return Otvet
|
|
//}
|
|
//
|
|
////
|
|
//TextImport := "import ("
|
|
//pos1 = strings.Index(Otvet, TextImport)
|
|
//if pos1 < 0 {
|
|
// log.Error("not found word: ", TextImport)
|
|
// return TextModel
|
|
//}
|
|
//
|
|
//Otvet = Otvet[:pos1+len(TextImport)] + "\n\t" + RepositoryURL + Otvet[pos1+len(TextImport):]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddImportTimestamp - добавляет покет в секцию Import, если его там нет
|
|
func AddImportTimestamp(Text string) string {
|
|
Otvet := Text
|
|
|
|
RepositoryURL := `google.golang.org/protobuf/types/known/timestamppb`
|
|
Otvet = AddImport(Text, RepositoryURL)
|
|
|
|
////если уже есть импорт
|
|
//pos1 := strings.Index(Otvet, `"google.golang.org/protobuf/types/known/timestamppb"`)
|
|
//if pos1 >= 0 {
|
|
// return Otvet
|
|
//}
|
|
//
|
|
////
|
|
//pos1 = strings.Index(Otvet, "import (")
|
|
//if pos1 < 0 {
|
|
// log.Error("not found word: import (")
|
|
// return TextModel
|
|
//}
|
|
//
|
|
//Otvet = Otvet[:pos1+8] + "\n\t" + `"google.golang.org/protobuf/types/known/timestamppb"` + Otvet[pos1+8:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportAlias - добавляет покет в секцию Alias, если его там нет
|
|
func CheckAndAddImportAlias(TextModel string) string {
|
|
Otvet := TextModel
|
|
|
|
//если уже есть импорт
|
|
pos1 := strings.Index(Otvet, `/alias`)
|
|
if pos1 >= 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//если нету alias
|
|
pos1 = strings.Index(Otvet, `alias.`)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//
|
|
pos1 = strings.Index(Otvet, "import (")
|
|
if pos1 < 0 {
|
|
log.Error("not found word: import (")
|
|
return TextModel
|
|
}
|
|
|
|
AliasURL := FindURL_Alias()
|
|
Otvet = Otvet[:pos1+8] + "\n\t" + `"` + AliasURL + `"` + Otvet[pos1+8:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportTime_FromTable - добавляет пакет "time" в секцию Import, если его там нет
|
|
func CheckAndAddImportTime_FromTable(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
HasTimeColumn := Has_ColumnType_Time(Table1)
|
|
if HasTimeColumn == false {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = AddImportTime(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportTime_FromText - добавляет пакет "time" в секцию Import, если его там нет
|
|
func CheckAndAddImportTime_FromText(Text string) string {
|
|
Otvet := Text
|
|
|
|
pos1 := strings.Index(Text, " time.")
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = AddImportTime(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportUUID_FromText - добавляет пакет "uuid" в секцию Import, если его там нет
|
|
func CheckAndAddImportUUID_FromText(Text string) string {
|
|
Otvet := Text
|
|
|
|
pos1 := strings.Index(Text, "uuid.")
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = AddImportUUID(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportGorm_FromText - добавляет пакет "gorm.io/gorm" в секцию Import, если его там нет
|
|
func CheckAndAddImportGorm_FromText(Text string) string {
|
|
Otvet := Text
|
|
|
|
pos1 := strings.Index(Text, `"gorm.io/gorm"`)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = AddImportGorm(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// CheckAndAddImportTimestamp_FromText - добавляет пакет "time" в секцию Import, если его там нет
|
|
func CheckAndAddImportTimestamp_FromText(Text string) string {
|
|
Otvet := Text
|
|
|
|
pos1 := strings.Index(Text, " timestamppb.")
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = AddImportTimestamp(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteTemplateRepositoryImports - удаляет импорты репозитория шаблона
|
|
func DeleteTemplateRepositoryImports(Text string) string {
|
|
Otvet := Text
|
|
|
|
if config.Settings.TEMPLATE_REPOSITORY_URL == "" {
|
|
return Otvet
|
|
}
|
|
|
|
//
|
|
TextFind := "import ("
|
|
pos1 := strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
log.Error("not found word: import (")
|
|
return Otvet
|
|
}
|
|
|
|
TextFind = `"` + config.Settings.TEMPLATE_REPOSITORY_URL
|
|
pos1 = strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
s2 := Otvet[pos1:]
|
|
posEnd := strings.Index(s2, "\n")
|
|
if posEnd < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1-1] + Otvet[pos1+posEnd+1:]
|
|
|
|
Otvet = DeleteTemplateRepositoryImports(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceServiceURLImports - заменяет URL репозитория шаблона на URL репозитория сервиса
|
|
func ReplaceServiceURLImports(Text string) string {
|
|
Otvet := Text
|
|
|
|
if config.Settings.SERVICE_REPOSITORY_URL == "" {
|
|
return Otvet
|
|
}
|
|
|
|
if config.Settings.TEMPLATE_REPOSITORY_URL == "" {
|
|
return Otvet
|
|
}
|
|
|
|
if config.Settings.USE_DEFAULT_TEMPLATE == false {
|
|
return Otvet
|
|
}
|
|
|
|
//
|
|
TextFind := "import ("
|
|
pos1 := strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
TEMPLATE_REPOSITORY_URL := config.Settings.TEMPLATE_REPOSITORY_URL
|
|
SERVICE_REPOSITORY_URL := config.Settings.SERVICE_REPOSITORY_URL
|
|
Otvet = strings.ReplaceAll(Otvet, TEMPLATE_REPOSITORY_URL, SERVICE_REPOSITORY_URL)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceModelAndTableName - заменяет имя модели и имя таблицы в шаблоне на новые
|
|
func ReplaceModelAndTableName(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, config.Settings.TEXT_TEMPLATE_MODEL, Table1.NameGo)
|
|
Otvet = strings.ReplaceAll(Otvet, config.Settings.TEXT_TEMPLATE_TABLENAME, Table1.Name)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindModelComment - возвращает комментарий для модели
|
|
func FindModelComment(Table1 *types.Table) string {
|
|
Otvet := ""
|
|
|
|
TableName := Table1.Name
|
|
ModelName := Table1.NameGo
|
|
COMMENT_MODEL_STRUCT := config.Settings.COMMENT_MODEL_STRUCT
|
|
|
|
Otvet = `// ` + ModelName + ` - ` + COMMENT_MODEL_STRUCT + TableName + `: ` + Table1.Comment
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindModelNameComment - возвращает комментарий для названия модели
|
|
func FindModelNameComment(ModelName string, Table1 *types.Table) string {
|
|
Otvet := ""
|
|
|
|
TableName := Table1.Name
|
|
//ModelName := Table1.NameGo
|
|
COMMENT_MODEL_STRUCT := config.Settings.COMMENT_MODEL_STRUCT
|
|
|
|
Otvet = `// ` + ModelName + ` - ` + COMMENT_MODEL_STRUCT + TableName + `: ` + Table1.Comment
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplacePackageName - заменяет имя пакета в шаблоне на новое
|
|
func ReplacePackageName(Text, PackageName string) string {
|
|
Otvet := Text
|
|
|
|
//найдём имя каталога, это будет имя пакета
|
|
PackageName = micro.DeleteEndSlash(PackageName)
|
|
PackageName = micro.LastWord(PackageName)
|
|
|
|
//
|
|
TextFind := "package "
|
|
pos1 := strings.Index(Otvet, TextFind)
|
|
if pos1 < 0 {
|
|
log.Error("not found word: package ")
|
|
return Otvet
|
|
}
|
|
|
|
s2 := Otvet[pos1:]
|
|
posEnd := strings.Index(s2, "\n")
|
|
if posEnd < 0 {
|
|
log.Error("not found word: \n")
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1+len(TextFind)] + PackageName + Otvet[pos1+posEnd:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteEmptyImport - удаляет пустой импорт
|
|
func DeleteEmptyImport(Text string) string {
|
|
Otvet := Text
|
|
|
|
sFind := `import (
|
|
)
|
|
`
|
|
Otvet = strings.ReplaceAll(Otvet, sFind, "")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncDelete - удаляет функцию Delete()
|
|
func DeleteFuncDelete(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// Delete ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "Delete")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncRestore - удаляет функцию Restore()
|
|
func DeleteFuncRestore(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true && config.Settings.HAS_IS_DELETED == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// Restore ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "Restore")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncFind_byExtID - удаляет функцию Find_ByExtID()
|
|
func DeleteFuncFind_byExtID(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверка есть ли колонки ExtID и ConnectionID
|
|
if Has_Column_ExtID_ConnectionID_Int64(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// Find_ByExtID ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "Find_ByExtID")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncDeleteCtx - удаляет функцию Delete_ctx()
|
|
func DeleteFuncDeleteCtx(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// Delete_ctx ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "Delete_ctx")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncRestoreCtx - удаляет функцию Restore_ctx()
|
|
func DeleteFuncRestoreCtx(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true && config.Settings.HAS_IS_DELETED == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// Restore_ctx ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "Restore_ctx")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncFind_byExtIDCtx - удаляет функцию Find_ByExtID_ctx()
|
|
func DeleteFuncFind_byExtIDCtx(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверка есть ли колонки ExtID и ConnectionID
|
|
if Has_Column_ExtID_ConnectionID_Int64(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// Find_ByExtID_ctx ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "Find_ByExtID_ctx")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncTestDelete - удаляет функцию Delete()
|
|
func DeleteFuncTestDelete(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// TestDelete ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "TestDelete")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncReadFromCache - удаляет функцию ReadFromCache()
|
|
func DeleteFuncReadFromCache(TextModel string, Table1 *types.Table) string {
|
|
Otvet := TextModel
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// ReadFromCache ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "ReadFromCache")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncTestRestore - удаляет функцию Restore()
|
|
func DeleteFuncTestRestore(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//проверим есть ли колонка IsDeleted
|
|
if Has_Column_IsDeleted_Bool(Table1) == true && config.Settings.HAS_IS_DELETED == true {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// TestRestore ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "TestRestore")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteFuncFind_byExtID - удаляет функцию Find_ByExtID()
|
|
func DeleteFuncTestFind_byExtID(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//проверка есть ли колонки ExtID и ConnectionID
|
|
if Has_Column_ExtID_ConnectionID_Int64(Table1) == true {
|
|
return Otvet
|
|
}
|
|
|
|
//
|
|
Otvet = DeleteFuncFromComment(Otvet, "\n// TestFind_ByExtID ")
|
|
Otvet = DeleteFuncFromFuncName(Otvet, "TestFind_ByExtID")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteEmptyLines - удаляет пустые строки
|
|
func DeleteEmptyLines(Text string) string {
|
|
Otvet := Text
|
|
Otvet = strings.ReplaceAll(Otvet, "\n\n\n", "\n\n")
|
|
Otvet = strings.ReplaceAll(Otvet, "\n//\n\n", "\n\n")
|
|
Otvet = strings.ReplaceAll(Otvet, "\n\t//\n\n", "\n\n")
|
|
//Otvet = strings.ReplaceAll(Otvet, "\r\r", "\r")
|
|
//Otvet = strings.ReplaceAll(Otvet, "\r\n", "\n")
|
|
//Otvet = strings.ReplaceAll(Otvet, "}\n\n", "}\n")
|
|
pos1 := strings.Index(Otvet, "\n\n\n")
|
|
if pos1 >= 0 {
|
|
Otvet = DeleteEmptyLines(Otvet)
|
|
}
|
|
|
|
//удалим последние 2 пустые строки
|
|
HasSuffix := strings.HasSuffix(Otvet, "\n\n")
|
|
if HasSuffix == true {
|
|
Otvet = Otvet[:len(Otvet)-1]
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteLastUnderline - удаляет последний символ подчёркивания
|
|
func DeleteLastUnderline(s string) string {
|
|
Otvet := s
|
|
if s == "" {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = strings.TrimSuffix(Otvet, "_")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindLastGoodPos - возвращает позицию последнего нахождения, с новой строки
|
|
func FindLastGoodPos(s, TextFind string) int {
|
|
Otvet := -1
|
|
pos1 := strings.LastIndex(s, TextFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
pos2 := strings.Index(s[pos1:], "\n")
|
|
if pos2 < 0 {
|
|
return Otvet
|
|
}
|
|
Otvet = pos1 + pos2 + 1
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// AddInterfaceFunction - добавляет функцию в интерфейс
|
|
func AddInterfaceFunction(s, TextAdd string) string {
|
|
Otvet := s
|
|
|
|
//Проверим такая функция уже есть
|
|
pos1 := strings.Index(Otvet, TextAdd)
|
|
if pos1 >= 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//найдём начало интефейса
|
|
sFind := " interface {"
|
|
pos1 = FindLastGoodPos(Otvet, sFind)
|
|
if pos1 < 0 {
|
|
log.Error("FindLastGoodPos() error: not found: ", sFind)
|
|
return Otvet
|
|
}
|
|
|
|
s2 := Otvet[pos1:]
|
|
pos2 := strings.Index(s2, "\n}")
|
|
if pos2 < 0 {
|
|
log.Error("FindLastGoodPos() error: not found: \\n")
|
|
return Otvet
|
|
}
|
|
PosStart := pos1 + pos2
|
|
|
|
Otvet = Otvet[:PosStart] + TextAdd + Otvet[PosStart:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextProtobufRequest - возвращает "RequestID" и "ID" - имя message из .proto, в зависимости от типа, а также название поля
|
|
func FindTextProtobufRequest(Table1 *types.Table) (OtvetRequestType string, OtvetRequestName string) {
|
|
|
|
if Table1.PrimaryKeyColumnsCount == 1 {
|
|
OtvetRequestType, OtvetRequestName = FindTextProtobufRequest1(Table1)
|
|
} else {
|
|
OtvetRequestType = FindTextProtobufRequest_ManyPK(Table1)
|
|
}
|
|
|
|
return OtvetRequestType, OtvetRequestName
|
|
}
|
|
|
|
// FindTextProtobufRequest1 - возвращает "RequestID" и "ID" - имя message из .proto, в зависимости от типа, а также название поля
|
|
func FindTextProtobufRequest1(Table1 *types.Table) (OtvetRequestType string, OtvetRequestName string) {
|
|
//OtvetRequestType := ""
|
|
//OtvetRequestName := ""
|
|
|
|
TextRequest := "Request_"
|
|
|
|
PrimaryKeyColumn := FindPrimaryKeyColumn(Table1)
|
|
if PrimaryKeyColumn == nil {
|
|
return "", ""
|
|
}
|
|
|
|
PrimaryKeyTypeGo := PrimaryKeyColumn.TypeGo
|
|
//switch PrimaryKeyTypeGo {
|
|
//case "string", "uuid.UUID":
|
|
// TextRequest = "Request"
|
|
//}
|
|
|
|
OtvetRequestName = PrimaryKeyColumn.TypeGo
|
|
|
|
OtvetRequestName = micro.StringFromUpperCase(OtvetRequestName)
|
|
OtvetRequestType = TextRequest + OtvetRequestName
|
|
|
|
switch PrimaryKeyTypeGo {
|
|
case "string", "uuid.UUID":
|
|
OtvetRequestName = "String_1"
|
|
OtvetRequestType = TextRequest + "String"
|
|
case "time.Time":
|
|
OtvetRequestName = "Date"
|
|
OtvetRequestType = TextRequest + "Date"
|
|
}
|
|
|
|
return OtvetRequestType, OtvetRequestName
|
|
}
|
|
|
|
// FindTextProtobufRequest_ManyPK - возвращает "RequestID" и "ID" - имя message из .proto, в зависимости от типа, а также название поля
|
|
func FindTextProtobufRequest_ManyPK(Table1 *types.Table) string {
|
|
Otvet := "Request"
|
|
|
|
MassPrimaryKeyColumns := FindPrimaryKeyColumns(Table1)
|
|
|
|
if len(MassPrimaryKeyColumns) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = FindTextProtobufRequest_Column_ManyPK(Table1, MassPrimaryKeyColumns[0])
|
|
|
|
//for _, ColumnPK1 := range MassPrimaryKeyColumns {
|
|
// Type1, _, _, _ := FindTextProtobufRequest_ID_Type(Table1, ColumnPK1, "")
|
|
// Otvet = Otvet + Type1
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextProtobufRequest_Column_ManyPK - возвращает "RequestID" и "ID" - имя message из .proto, в зависимости от типа, а также название поля
|
|
func FindTextProtobufRequest_Column_ManyPK(Table1 *types.Table, Column1 *types.Column) string {
|
|
Otvet := "Request"
|
|
|
|
MassPrimaryKeyColumns := FindPrimaryKeyColumns(Table1)
|
|
|
|
if len(MassPrimaryKeyColumns) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
IsPrimaryKey := false
|
|
for _, ColumnPK1 := range MassPrimaryKeyColumns {
|
|
if Column1 == ColumnPK1 {
|
|
IsPrimaryKey = true
|
|
}
|
|
Type1, _, _, _ := FindTextProtobufRequest_ID_Type(Table1, ColumnPK1, "")
|
|
Otvet = Otvet + Type1
|
|
}
|
|
|
|
if IsPrimaryKey == false {
|
|
Type1, _, _, _ := FindTextProtobufRequest_ID_Type(Table1, Column1, "")
|
|
Otvet = Otvet + Type1
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextProtobufRequest_ID_Type - возвращает имя message из .proto для двух параметров ID + Type,в зависимости от типа, а также название поля
|
|
// возвращает:
|
|
// RequestName - имя message из .proto
|
|
// TextRequestFieldName - название поля в Request
|
|
// TextRequestFieldGolang - название поля в Request с преобразованием в тип гоу
|
|
// TextGolangLine - замена всей строки в го
|
|
func FindTextProtobufRequest_ID_Type(Table1 *types.Table, Column1 *types.Column, VariableName string) (RequestName string, RequestFieldName string, RequestFieldGolang string, GolangLine string) {
|
|
//RequestName := "RequestId"
|
|
//RequestFieldName := "ID"
|
|
//RequestFieldGolang := "ID"
|
|
//GolangLine := ""
|
|
|
|
TypeGo := Column1.TypeGo
|
|
TableName := Table1.Name
|
|
ColumnName := Column1.Name
|
|
|
|
//найдём тип колонки PrimaryKey
|
|
PrimaryKeyColumns := FindPrimaryKeyColumns(Table1)
|
|
if len(PrimaryKeyColumns) == 0 {
|
|
return "", "", "", ""
|
|
}
|
|
|
|
isPrimaryKey := false
|
|
Number := 0
|
|
for _, ColumnPK1 := range PrimaryKeyColumns {
|
|
if Column1.TypeGo == ColumnPK1.TypeGo {
|
|
Number = Number + 1
|
|
} else if IsStringOrUUID(ColumnPK1.TypeGo) == true && IsStringOrUUID(Column1.TypeGo) == true {
|
|
Number = Number + 1
|
|
}
|
|
if ColumnPK1 == Column1 {
|
|
isPrimaryKey = true
|
|
break
|
|
}
|
|
}
|
|
if isPrimaryKey == false {
|
|
Number = Number + 1
|
|
}
|
|
sNumber := ""
|
|
if IsStringOrUUID(Column1.TypeGo) == true {
|
|
sNumber = strconv.Itoa(Number)
|
|
sNumber = "_" + sNumber
|
|
} else if Number != 1 {
|
|
sNumber = strconv.Itoa(Number)
|
|
sNumber = "_" + sNumber
|
|
}
|
|
|
|
//RequestName, _ = FindTextProtobufRequest(Table1)
|
|
|
|
TextRequestProtoName := ""
|
|
|
|
//найдём строку по типу колонки
|
|
switch TypeGo {
|
|
case "int", "int64":
|
|
{
|
|
TextRequestProtoName = "Int64"
|
|
RequestFieldName = "Int64" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
|
|
case "int32":
|
|
{
|
|
TextRequestProtoName = "Int32"
|
|
RequestFieldName = "Int32" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
case "string":
|
|
{
|
|
TextRequestProtoName = "String"
|
|
RequestFieldName = "String" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
case "uuid.UUID":
|
|
{
|
|
TextRequestProtoName = "String"
|
|
RequestFieldName = "String" + sNumber
|
|
GolangLine = Column1.NameGo + ", err := uuid.Parse(" + VariableName + "" + RequestFieldName + ")" + `
|
|
if Request.` + RequestFieldName + ` == "" {
|
|
` + Column1.NameGo + ` = uuid.Nil
|
|
err = nil
|
|
}
|
|
if err != nil {
|
|
return &Otvet, err
|
|
}
|
|
`
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
case "time.Time":
|
|
{
|
|
TextRequestProtoName = "Date"
|
|
RequestFieldName = "Date" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName + ".AsTime()"
|
|
}
|
|
case "float32":
|
|
{
|
|
TextRequestProtoName = "Float32"
|
|
RequestFieldName = "Float32" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
case "float64":
|
|
{
|
|
TextRequestProtoName = "Float64"
|
|
RequestFieldName = "Float64" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
case "bool":
|
|
{
|
|
TextRequestProtoName = "Bool"
|
|
RequestFieldName = "Bool" + sNumber
|
|
RequestFieldGolang = VariableName + RequestFieldName
|
|
}
|
|
}
|
|
|
|
TextConvert, ok := types.MapConvertID[TableName+"."+ColumnName]
|
|
if ok == true {
|
|
RequestFieldGolang = TextConvert + "(" + VariableName + RequestFieldName + ")"
|
|
}
|
|
|
|
RequestName = RequestName + "_" + TextRequestProtoName
|
|
|
|
return RequestName, RequestFieldName, RequestFieldGolang, GolangLine
|
|
}
|
|
|
|
// IsStringOrUUID - проверяет является ли тип String или UUID
|
|
func IsStringOrUUID(TypeGo string) bool {
|
|
if TypeGo == "string" || TypeGo == "uuid.UUID" {
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
// ConvertRequestIdToAlias - заменяет ID на Alias
|
|
func ConvertRequestIdToAlias(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
TableName := Table1.Name
|
|
IDName, _ := FindPrimaryKeyNameType(Table1)
|
|
TextConvert, ok := types.MapConvertID[TableName+"."+IDName]
|
|
if ok == false {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "Request.ID", TextConvert+"(Request.ID)")
|
|
if TextConvert[:6] != "alias." {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = CheckAndAddImportAlias(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceIDToAlias_OtvetID - заменяет "Otvet.ID = ID" на "Otvet.ID = alias.Name(ID)"
|
|
func ReplaceIDToAlias_OtvetID(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
TableName := Table1.Name
|
|
IDName, _ := FindPrimaryKeyNameType(Table1)
|
|
TextConvert, ok := types.MapConvertID[TableName+"."+IDName]
|
|
if ok == false {
|
|
return Otvet
|
|
}
|
|
|
|
if TextConvert[:6] != "alias." {
|
|
return Otvet
|
|
}
|
|
|
|
TextFrom := constants.TEXT_OTVET_ID_ALIAS
|
|
TextTo := TextFrom
|
|
TextTo = strings.ReplaceAll(TextFrom, " AliasFromInt(ID)", " "+TextConvert+"(ID)")
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, TextFrom, TextTo)
|
|
//URL := FindURL_Alias()
|
|
//if URL == "" {
|
|
// return Otvet
|
|
//}
|
|
|
|
Otvet = CheckAndAddImportAlias(Otvet)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertIDToAlias - заменяет "ID" на "alias.Name(ID)"
|
|
func ConvertIDToAlias(Table1 *types.Table, Column1 *types.Column, VariableName string) string {
|
|
Otvet := VariableName
|
|
|
|
TableName := Table1.Name
|
|
TextConvert, ok := types.MapConvertID[TableName+"."+Column1.Name]
|
|
if ok == false {
|
|
return Otvet
|
|
}
|
|
|
|
if TextConvert[:6] != "alias." {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = TextConvert + "(" + VariableName + ")"
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertColumnToAlias - заменяет "Otvet.ID = ID" на "Otvet.ID = alias.Name(ID)"
|
|
func ConvertColumnToAlias(Table1 *types.Table, Column1 *types.Column, VariableName string) string {
|
|
Otvet := ""
|
|
|
|
Dot := ""
|
|
if VariableName != "" {
|
|
Dot = "."
|
|
}
|
|
Otvet = VariableName + Dot + Column1.NameGo
|
|
|
|
TableName := Table1.Name
|
|
IDName := Column1.Name
|
|
TextConvert, ok := types.MapConvertID[TableName+"."+IDName]
|
|
if ok == false {
|
|
return Otvet
|
|
}
|
|
|
|
if TextConvert[:6] != "alias." {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = TextConvert + "(" + VariableName + Dot + Column1.NameGo + ")"
|
|
|
|
//добавим испорт
|
|
//Text = CheckAndAddImportAlias(Text)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// DeleteCommentFromString - удаляет комментарий из строки //
|
|
func DeleteCommentFromString(TextFrom string) string {
|
|
Otvet := TextFrom
|
|
|
|
pos1 := strings.Index(Otvet, "//")
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertGolangVariableToProtobufVariable - возвращает имя переменной + имя колонки, преобразованное в тип protobuf
|
|
func ConvertGolangVariableToProtobufVariable(Column1 *types.Column, VariableName string) string {
|
|
Otvet := ""
|
|
|
|
if Column1 == nil {
|
|
return Otvet
|
|
}
|
|
|
|
Dot := ""
|
|
if VariableName != "" {
|
|
Dot = "."
|
|
}
|
|
Otvet = VariableName + Dot + Column1.NameGo
|
|
|
|
//преобразуем alias в обычный тип, и дату в timestamp
|
|
switch Column1.TypeGo {
|
|
case "time.Time":
|
|
Otvet = "timestamppb.New(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "string":
|
|
Otvet = "string(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "int64":
|
|
Otvet = "int64(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "int32":
|
|
Otvet = "int32(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "bool":
|
|
Otvet = "bool(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "float32":
|
|
Otvet = "float32(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "float64":
|
|
Otvet = "float64(" + VariableName + Dot + Column1.NameGo + ")"
|
|
case "uuid.UUID":
|
|
Otvet = VariableName + Dot + Column1.NameGo + ".String()"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
//// ConvertVariableToProtobufType - возвращает имя переменной + имя колонки, преобразованное в тип protobuf
|
|
//func ConvertVariableToProtobufType(Column1 *types.Column, VariableName string) string {
|
|
// Otvet := ""
|
|
//
|
|
// if Column1 == nil {
|
|
// return Otvet
|
|
// }
|
|
//
|
|
// Otvet = VariableName
|
|
//
|
|
// switch Column1.TypeGo {
|
|
// case "time.Time":
|
|
// Otvet = "timestamppb.New(" + VariableName + ")"
|
|
// case "uuid.UUID":
|
|
// Otvet = VariableName + ".String()"
|
|
// }
|
|
//
|
|
// return Otvet
|
|
//}
|
|
|
|
// ConvertProtobufVariableToGolangVariable - возвращает имя переменной + имя колонки, преобразованное в тип golang из protobuf
|
|
func ConvertProtobufVariableToGolangVariable(Table1 *types.Table, Column1 *types.Column, VariableName string) (VariableColumn string, GolangCode string) {
|
|
RequestColumnName := FindRequestFieldName(Table1, Column1)
|
|
VariableColumn = VariableName + RequestColumnName
|
|
//time.Time в timestamppb
|
|
switch Column1.TypeGo {
|
|
case "time.Time":
|
|
{
|
|
VariableColumn = VariableName + RequestColumnName + ".AsTime()"
|
|
return VariableColumn, GolangCode
|
|
}
|
|
case "uuid.UUID":
|
|
{
|
|
VariableColumn = "uuid.FromBytes([]byte(" + VariableName + RequestColumnName + "))"
|
|
GolangCode = Column1.NameGo + `, err := uuid.FromBytes([]byte(Request.` + RequestColumnName + `))
|
|
if err != nil {
|
|
return &Otvet, err
|
|
}
|
|
`
|
|
return VariableColumn, GolangCode
|
|
}
|
|
}
|
|
|
|
return VariableColumn, GolangCode
|
|
}
|
|
|
|
// ConvertProtobufTypeToGolangAlias - возвращает имя переменной + имя колонки, преобразованное в тип golang(alias) из protobuf
|
|
func ConvertProtobufTypeToGolangAlias(Table1 *types.Table, Column1 *types.Column, VariableName string) (VariableColumn string, GolangCode string) {
|
|
RequestColumnName := FindRequestFieldName(Table1, Column1)
|
|
VariableColumn = VariableName + RequestColumnName
|
|
//GolangCode := ""
|
|
|
|
TableName := Table1.Name
|
|
IDName := Column1.Name
|
|
|
|
//alias в Int64
|
|
TextConvert, ok := types.MapConvertID[TableName+"."+IDName]
|
|
if ok == true {
|
|
VariableColumn = TextConvert + "(" + VariableName + RequestColumnName + ")"
|
|
return VariableColumn, GolangCode
|
|
}
|
|
|
|
//time.Time в timestamppb
|
|
switch Column1.TypeGo {
|
|
case "time.Time":
|
|
{
|
|
VariableColumn = VariableName + RequestColumnName + ".AsTime()"
|
|
return VariableColumn, GolangCode
|
|
}
|
|
case "uuid.UUID":
|
|
{
|
|
VariableColumn = "uuid.FromBytes([]byte(" + VariableName + RequestColumnName + "))"
|
|
GolangCode = Column1.NameGo + `, err := uuid.FromBytes([]byte(Request.` + RequestColumnName + `))
|
|
if err != nil {
|
|
return &Otvet, err
|
|
}
|
|
`
|
|
return VariableColumn, GolangCode
|
|
}
|
|
}
|
|
|
|
return VariableColumn, GolangCode
|
|
}
|
|
|
|
// FindTextEqualEmpty - находит текст сравнение с пустым значением
|
|
func FindTextEqualEmpty(Column1 *types.Column, VariableName string) string {
|
|
Otvet := ""
|
|
|
|
DefaultValue := FindTextDefaultValue(Column1.TypeGo)
|
|
Otvet = VariableName + " == " + DefaultValue
|
|
|
|
if DefaultValue == "time.Time{}" {
|
|
Otvet = VariableName + ".IsZero() == true"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
//// AddSkipNowEveryFunc - добавляет функцию SkipNow() для каждой тестовой функции
|
|
//func AddSkipNowEveryFunc(Text string) string {
|
|
// Otvet := ""
|
|
//
|
|
// sFind := "\nfunc "
|
|
// Mass := make([]string, 0)
|
|
// Mass = strings.Split(Text, sFind)
|
|
// for _, v := range Mass {
|
|
// pos1 := strings.Index(v, sFind)
|
|
// if pos1 < 0 {
|
|
// continue
|
|
// }
|
|
//
|
|
// s2 := Text[pos1:]
|
|
// pos2 := strings.Index(s2, "\n")
|
|
// if pos2 < 0 {
|
|
// continue
|
|
// }
|
|
// v = v[:pos1+pos2] + "\n\tt.SkipNow() //нет строк в БД \n" + v[pos1+pos2:]
|
|
// Otvet = Otvet + v
|
|
// }
|
|
//
|
|
// return Otvet
|
|
//}
|
|
|
|
// FilenameWithoutLastUnderline - удаляет последний символ, если он = "_"
|
|
func FilenameWithoutLastUnderline(Filename string) string {
|
|
Otvet := Filename
|
|
|
|
if strings.HasSuffix(Filename, "_") == true {
|
|
Otvet = Filename[:len(Filename)-1]
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FillVariable - заменяет переменную в тексте
|
|
func FillVariable(Text, VariableName, Value string) string {
|
|
Otvet := Text
|
|
|
|
sFind := VariableName + " = "
|
|
pos1 := strings.Index(Otvet, sFind)
|
|
if pos1 < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
s2 := Text[pos1:]
|
|
posEnd := strings.Index(s2, "\n")
|
|
if posEnd < 0 {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = Otvet[:pos1] + VariableName + " = " + Value + Otvet[pos1+posEnd:]
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Is_UUID_Type - проверяет является ли тип UUID
|
|
func Is_UUID_Type(TypeGo string) bool {
|
|
Otvet := TypeGo == "uuid.UUID" || TypeGo == "uuid.NullUUID"
|
|
return Otvet
|
|
}
|
|
|
|
// Replace_Postgres_ID_Test - заменяет текст "const Postgres_ID_Test = 0" на нужный ИД
|
|
func Replace_Postgres_ID_Test(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//if Table1.PrimaryKeyColumnsCount == 1 {
|
|
// ColumnPK := FindPrimaryKeyColumn(Table1)
|
|
// if ColumnPK == nil {
|
|
// return Otvet
|
|
// }
|
|
//
|
|
// Otvet = Replace_Postgres_ID_Test1(Otvet, Table1, ColumnPK)
|
|
// TextFind := "Postgres_ID_Test"
|
|
// PrimaryKeyName := strings.ToUpper(ColumnPK.NameGo)
|
|
// Otvet = strings.ReplaceAll(Otvet, "\tm1.ID = "+TextFind, "\tm1."+ColumnPK.NameGo+" = "+TextFind)
|
|
// Otvet = strings.ReplaceAll(Otvet, TextFind, PrimaryKeyName+`_Test`)
|
|
// //Otvet = strings.ReplaceAll(Otvet, TextFind, PrimaryKeyName+`_Test`)
|
|
// //Otvet = strings.ReplaceAll(Otvet, TextFind, `Postgres_`+PrimaryKeyName+`_Test`)
|
|
//} else {
|
|
Otvet = Replace_Postgres_ID_Test_ManyPK(Otvet, Table1)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Replace_Postgres_ID_Test_ManyPK - заменяет текст "const Postgres_ID_Test = 0" на нужные ИД, для много колонок PrimaryKey
|
|
func Replace_Postgres_ID_Test_ManyPK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
MassPK := FindPrimaryKeyColumns(Table1)
|
|
if len(MassPK) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//заменим const Postgres_ID_Test = 0
|
|
TextFind := "const Postgres_ID_Test = 0\n"
|
|
TextNew := ""
|
|
for _, PrimaryKey1 := range MassPK {
|
|
TextNew = TextNew + Replace_Postgres_ID_Test1(TextFind, Table1, PrimaryKey1)
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//заменим Otvet.ID = Postgres_ID_Test
|
|
TextFind = "\tOtvet.ID = Postgres_ID_Test\n"
|
|
TextNew = ""
|
|
for _, PrimaryKey1 := range MassPK {
|
|
Text1 := FindTextVariableEqual_ColumnName_Test(PrimaryKey1, "Otvet."+PrimaryKey1.NameGo)
|
|
TextNew = TextNew + "\t" + Text1 + "\n"
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//заменим m.ID = Postgres_ID_Test
|
|
TextFind = "\tm.ID = Postgres_ID_Test\n"
|
|
TextNew = ""
|
|
for _, PrimaryKey1 := range MassPK {
|
|
Text1 := FindTextVariableEqual_ColumnName_Test(PrimaryKey1, "m."+PrimaryKey1.NameGo)
|
|
TextNew = TextNew + "\t" + Text1 + "\n"
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//заменим m1.ID = Postgres_ID_Test
|
|
TextFind = "\tm1.ID = Postgres_ID_Test\n"
|
|
TextNew = ""
|
|
for _, PrimaryKey1 := range MassPK {
|
|
Text1 := FindTextVariableEqual_ColumnName_Test(PrimaryKey1, "m1."+PrimaryKey1.NameGo)
|
|
TextNew = TextNew + "\t" + Text1 + "\n"
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//заменим ReadFromCache(Postgres_ID_Test)
|
|
TextFind = "ReadFromCache(Postgres_ID_Test)"
|
|
TextNew = "ReadFromCache("
|
|
Comma := ""
|
|
for _, PrimaryKey1 := range MassPK {
|
|
Name := FindTextColumnNameTest(PrimaryKey1)
|
|
TextNew = TextNew + Comma + Name
|
|
Comma = ", "
|
|
}
|
|
TextNew = TextNew + ")"
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
// //удалим лишний код
|
|
// TextDelete := ` if Otvet.ID != Postgres_ID_Test {
|
|
// t.Error(TableName + "_test.TestRead() error ID != ", Postgres_ID_Test)
|
|
// } else {
|
|
// t.Log(TableName+"_test.TestRead() Otvet: ", Otvet.ID)
|
|
// }
|
|
//`
|
|
// Otvet = strings.ReplaceAll(Otvet, TextDelete, "")
|
|
|
|
//заменим ненужные Otvet.ID на Otvet.Name
|
|
PrimaryKey1 := MassPK[0]
|
|
Otvet = strings.ReplaceAll(Otvet, " Otvet.ID ", " Otvet."+PrimaryKey1.NameGo+" ")
|
|
Otvet = strings.ReplaceAll(Otvet, " Otvet.ID)", " Otvet."+PrimaryKey1.NameGo+")")
|
|
Name := FindTextColumnNameTest(PrimaryKey1)
|
|
Otvet = strings.ReplaceAll(Otvet, "Postgres_ID_Test", Name)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextColumnNameTest - находит имя переменной для тестов
|
|
func FindTextColumnNameTest(Column1 *types.Column) string {
|
|
Otvet := ""
|
|
Otvet = strings.ToUpper(Column1.NameGo) + "_Test"
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextNameTest_ManyPK - находит текст "ID, ID" для тестов
|
|
func FindTextNameTest_ManyPK(Table1 *types.Table) string {
|
|
Otvet := ""
|
|
|
|
MassPK := FindPrimaryKeyColumns(Table1)
|
|
if len(MassPK) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
for _, PrimaryKey1 := range MassPK {
|
|
Otvet = Otvet + FindTextColumnNameTest(PrimaryKey1) + ", "
|
|
}
|
|
Otvet = strings.TrimSuffix(Otvet, ", ")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Replace_Postgres_ID_Test1 - заменяет текст "const Postgres_ID_Test = 0" на нужный ИД
|
|
func Replace_Postgres_ID_Test1(Text string, Table1 *types.Table, PrimaryKeyColumn *types.Column) string {
|
|
Otvet := Text
|
|
|
|
TextFind := "const Postgres_ID_Test = 0"
|
|
IDMinimum := PrimaryKeyColumn.IDMinimum
|
|
if IDMinimum == "" {
|
|
IDMinimum = FindTextDefaultValue(PrimaryKeyColumn.TypeGo)
|
|
}
|
|
|
|
Name := FindTextColumnNameTest(PrimaryKeyColumn)
|
|
sIDMinimum := FindTextIDMinimum(PrimaryKeyColumn)
|
|
switch PrimaryKeyColumn.TypeGo {
|
|
case "uuid.UUID":
|
|
{
|
|
if PrimaryKeyColumn.IDMinimum == "" {
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `var `+Name+` = `+sIDMinimum)
|
|
} else {
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `var `+Name+`, _ = `+sIDMinimum)
|
|
}
|
|
}
|
|
case "string":
|
|
{
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `const `+Name+` = `+sIDMinimum+``)
|
|
}
|
|
default:
|
|
{
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `const `+Name+` = `+sIDMinimum)
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextVariableEqual_ColumnName_Test - возвращает текст для присваивания переменной IDMinimum
|
|
func FindTextVariableEqual_ColumnName_Test(Column1 *types.Column, VariableName string) string {
|
|
Otvet := ""
|
|
|
|
//TextValue := FindTextIDMinimum(Column1)
|
|
TextValue := FindTextColumnNameTest(Column1)
|
|
|
|
IDMinimum := Column1.IDMinimum
|
|
switch Column1.TypeGo {
|
|
case "uuid.UUID":
|
|
{
|
|
if IDMinimum == "" {
|
|
Otvet = VariableName + " = " + "uuid.Nil"
|
|
} else {
|
|
Otvet = VariableName + ", _ = " + `uuid.Parse("` + IDMinimum + `")`
|
|
}
|
|
}
|
|
default:
|
|
{
|
|
Otvet = VariableName + " = " + TextValue
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextIDMinimum - возвращает текст для IDMinimum, в зависимости от типа
|
|
func FindTextIDMinimum(Column1 *types.Column) string {
|
|
Otvet := ""
|
|
|
|
IDMinimum := Column1.IDMinimum
|
|
if IDMinimum == "" {
|
|
IDMinimum = FindTextDefaultValue(Column1.TypeGo)
|
|
}
|
|
|
|
switch Column1.TypeGo {
|
|
case "uuid.UUID":
|
|
{
|
|
if Column1.IDMinimum == "" {
|
|
Otvet = "uuid.Nil"
|
|
} else {
|
|
Otvet = `uuid.Parse("` + IDMinimum + `")`
|
|
}
|
|
}
|
|
case "string":
|
|
{
|
|
Otvet = `"` + IDMinimum + `"`
|
|
}
|
|
default:
|
|
{
|
|
Otvet = `` + IDMinimum + ``
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Replace_Model_ID_Test - заменяет текст "const LawsuitStatusType_ID_Test = 0" на нужный ИД
|
|
func Replace_Model_ID_Test(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//if Table1.PrimaryKeyColumnsCount == 1 {
|
|
// PrimaryKeyColumn := FindPrimaryKeyColumn(Table1)
|
|
// if PrimaryKeyColumn == nil {
|
|
// return Otvet
|
|
// }
|
|
//
|
|
// Otvet = Replace_Model_ID_Test1(Otvet, Table1, PrimaryKeyColumn)
|
|
//} else {
|
|
Otvet = Replace_Model_ID_Test_ManyPK(Otvet, Table1)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Replace_Model_ID_Test_ManyPK - заменяет текст "const Postgres_ID_Test = 0" на нужные ИД, для много колонок PrimaryKey
|
|
func Replace_Model_ID_Test_ManyPK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
MassPK := FindPrimaryKeyColumns(Table1)
|
|
if len(MassPK) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//заменим const Postgres_ID_Test = 0
|
|
TextFind := "const LawsuitStatusType_ID_Test = 0\n"
|
|
TextNew := ""
|
|
for _, Column1 := range MassPK {
|
|
TextNew = TextNew + Replace_Model_ID_Test1(TextFind, Table1, Column1)
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//заменим Request.ID = LawsuitStatusType_ID_Test
|
|
TextFind = "\tRequest.ID = LawsuitStatusType_ID_Test\n"
|
|
TextNew = ""
|
|
for _, Column1 := range MassPK {
|
|
Name := strings.ToUpper(Column1.NameGo)
|
|
VariableName := Table1.NameGo + "_" + Name + "_Test"
|
|
Text1 := ConvertGolangVariableToProtobufVariable(Column1, VariableName)
|
|
RequestColumnName := FindRequestFieldName(Table1, Column1)
|
|
TextNew = TextNew + "\tRequest." + RequestColumnName + " = " + Text1 + "\n"
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//заменим Request.ID = LawsuitStatusType_ID_Test
|
|
TextFind = "\tRequest2.ID = LawsuitStatusType_ID_Test\n"
|
|
TextNew = ""
|
|
for _, Column1 := range MassPK {
|
|
Name := strings.ToUpper(Column1.NameGo)
|
|
VariableName := Table1.NameGo + "_" + Name + "_Test"
|
|
Text1 := ConvertGolangVariableToProtobufVariable(Column1, VariableName)
|
|
RequestColumnName := FindRequestFieldName(Table1, Column1)
|
|
TextNew = TextNew + "\tRequest2." + RequestColumnName + " = " + Text1 + "\n"
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// Replace_Model_ID_Test1 - заменяет текст "const LawsuitStatusType_ID_Test = 0" на нужный ИД
|
|
func Replace_Model_ID_Test1(Text string, Table1 *types.Table, Column1 *types.Column) string {
|
|
Otvet := Text
|
|
|
|
TEXT_TEMPLATE_MODEL := config.Settings.TEXT_TEMPLATE_MODEL
|
|
//ModelName := Table1.NameGo
|
|
TextFind := "const " + TEXT_TEMPLATE_MODEL + "_ID_Test = 0"
|
|
|
|
IDMinimum := Column1.IDMinimum
|
|
if IDMinimum == "" {
|
|
IDMinimum = FindTextDefaultValue(Column1.TypeGo)
|
|
}
|
|
DefaultModelName := config.Settings.TEXT_TEMPLATE_MODEL
|
|
|
|
ModelName := Table1.NameGo
|
|
Name := FindTextColumnNameTest(Column1)
|
|
switch Column1.TypeGo {
|
|
case "uuid.UUID":
|
|
{
|
|
if Column1.IDMinimum == "" {
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `var `+ModelName+"_"+Name+` = `+IDMinimum+``)
|
|
} else {
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `var `+ModelName+"_"+Name+`, _ = uuid.Parse("`+IDMinimum+`")`)
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, ``+DefaultModelName+`_ID_Test`, ``+ModelName+`_`+Name+`.String()`)
|
|
}
|
|
case "string":
|
|
{
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `const `+ModelName+`_`+Name+` = "`+IDMinimum+`"`)
|
|
}
|
|
default:
|
|
{
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, `const `+ModelName+`_`+Name+` = `+IDMinimum)
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceTextRequestID_and_Column - заменяет RequestId{} на RequestString{}
|
|
func ReplaceTextRequestID_and_Column(Text string, Table1 *types.Table, Column1 *types.Column) string {
|
|
Otvet := Text
|
|
|
|
//TypeGo := Column1.TypeGo
|
|
|
|
TextRequestID, _, _, _ := FindTextProtobufRequest_ID_Type(Table1, Column1, "Request")
|
|
Otvet = strings.ReplaceAll(Otvet, "RequestId{}", TextRequestID+"{}")
|
|
//Otvet = strings.ReplaceAll(Otvet, "Request.ID", "Request."+TextID)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceTextRequestID_PrimaryKey - заменяет RequestId{} на RequestString{}
|
|
func ReplaceTextRequestID_PrimaryKey(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//if Table1.PrimaryKeyColumnsCount == 1 {
|
|
// TextRequest := "Request"
|
|
// Otvet = ReplaceTextRequestID_PrimaryKey1(Otvet, Table1, TextRequest)
|
|
//
|
|
// TextRequest = "Request2"
|
|
// Otvet = ReplaceTextRequestID_PrimaryKey1(Otvet, Table1, TextRequest)
|
|
//} else {
|
|
TextRequest := "Request"
|
|
Otvet = ReplaceTextRequestID_PrimaryKey_ManyPK(Otvet, Table1, TextRequest)
|
|
|
|
TextRequest = "Request2"
|
|
Otvet = ReplaceTextRequestID_PrimaryKey_ManyPK(Otvet, Table1, TextRequest)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceTextRequestID_PrimaryKey1 - заменяет RequestId{} на RequestString{}
|
|
func ReplaceTextRequestID_PrimaryKey1(Text string, Table1 *types.Table, VariableName string) string {
|
|
Otvet := Text
|
|
|
|
ColumnPK := FindPrimaryKeyColumn(Table1)
|
|
if ColumnPK == nil {
|
|
return Otvet
|
|
}
|
|
|
|
//TypeGo := ColumnPK.TypeGo
|
|
|
|
TextRequestID, TextID := FindTextProtobufRequest(Table1)
|
|
|
|
_, GolangCode := ConvertProtobufVariableToGolangVariable(Table1, ColumnPK, "Request.")
|
|
if GolangCode != "" {
|
|
Otvet = strings.ReplaceAll(Otvet, "ID := "+VariableName+".ID", GolangCode)
|
|
Otvet = strings.ReplaceAll(Otvet, VariableName+".ID = ", VariableName+"."+TextID+" = ")
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "RequestId{}", TextRequestID+"{}")
|
|
Otvet = strings.ReplaceAll(Otvet, "*grpc_proto.RequestId", "*grpc_proto."+TextRequestID)
|
|
//Otvet = strings.ReplaceAll(Otvet, "Request.ID", "Request."+TextID)
|
|
Otvet = strings.ReplaceAll(Otvet, "ID := "+VariableName+".ID", ColumnPK.NameGo+" := "+VariableName+"."+TextID)
|
|
Otvet = strings.ReplaceAll(Otvet, VariableName+".ID", VariableName+"."+TextID)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceTextRequestID_PrimaryKey_ManyPK - заменяет RequestId{} на RequestString{}
|
|
func ReplaceTextRequestID_PrimaryKey_ManyPK(Text string, Table1 *types.Table, TextRequest string) string {
|
|
Otvet := Text
|
|
|
|
TextRequestID := FindTextProtobufRequest_ManyPK(Table1)
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "RequestId{}", TextRequestID+"{}")
|
|
Otvet = strings.ReplaceAll(Otvet, "*grpc_proto.RequestId", "*grpc_proto."+TextRequestID)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
func ReplaceIDtoID(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
PrimaryKeyCount := Table1.PrimaryKeyColumnsCount
|
|
if PrimaryKeyCount == 1 {
|
|
Otvet = ReplaceIDtoID1(Otvet, Table1)
|
|
} else {
|
|
Otvet = ReplaceIDtoID_Many(Otvet, Table1)
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceIDtoID1 - заменяет int64(ID) на ID
|
|
func ReplaceIDtoID1(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
PrimaryKeyColumn := FindPrimaryKeyColumn(Table1)
|
|
OtvetColumnName := ConvertGolangVariableToProtobufVariable(PrimaryKeyColumn, "")
|
|
if OtvetColumnName == "" {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(ID)", OtvetColumnName)
|
|
Otvet = strings.ReplaceAll(Otvet, "(ID int64", "("+PrimaryKeyColumn.NameGo+" "+PrimaryKeyColumn.TypeGo)
|
|
Otvet = strings.ReplaceAll(Otvet, "(ID)", "("+PrimaryKeyColumn.NameGo+")")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextIDMany - находит все PrimaryKey строкой
|
|
func FindTextIDMany(Table1 *types.Table) (TextNames, TextNamesTypes, TextProtoNames string) {
|
|
//TextProtoNames := ""
|
|
//TextNamesTypes := ""
|
|
//TextNames := ""
|
|
|
|
TextNames, TextNamesTypes, TextProtoNames = FindTextID_VariableName_Many(Table1, "")
|
|
|
|
//Comma := ""
|
|
//MassPrimaryKey := FindPrimaryKeyColumns(Table1)
|
|
//for _, PrimaryKey1 := range MassPrimaryKey {
|
|
// OtvetColumnName := ConvertGolangVariableToProtobufVariable(Table1, PrimaryKey1, "")
|
|
// if OtvetColumnName == "" {
|
|
// continue
|
|
// }
|
|
//
|
|
// TextProtoNames = TextProtoNames + Comma + OtvetColumnName
|
|
// TextNamesTypes = TextNamesTypes + Comma + PrimaryKey1.NameGo + " " + PrimaryKey1.TypeGo
|
|
// TextNames = TextNames + Comma + PrimaryKey1.NameGo
|
|
//
|
|
// Comma = ", "
|
|
//}
|
|
|
|
return
|
|
}
|
|
|
|
// FindTextID_VariableName_Many - находит все PrimaryKey строкой
|
|
func FindTextID_VariableName_Many(Table1 *types.Table, VariableName string) (TextNames, TextNamesTypes, TextProtoNames string) {
|
|
//TextProtoNames := ""
|
|
//TextNamesTypes := ""
|
|
//TextNames := ""
|
|
|
|
Dot := ""
|
|
if VariableName != "" {
|
|
Dot = "."
|
|
}
|
|
Comma := ""
|
|
MassPrimaryKey := FindPrimaryKeyColumns(Table1)
|
|
for _, PrimaryKey1 := range MassPrimaryKey {
|
|
OtvetColumnName := ConvertGolangVariableToProtobufVariable(PrimaryKey1, "")
|
|
if OtvetColumnName == "" {
|
|
continue
|
|
}
|
|
|
|
TextProtoNames = TextProtoNames + Comma + OtvetColumnName
|
|
TextNamesTypes = TextNamesTypes + Comma + PrimaryKey1.NameGo + " " + PrimaryKey1.TypeGo
|
|
TextNames = TextNames + Comma + VariableName + Dot + PrimaryKey1.NameGo
|
|
|
|
Comma = ", "
|
|
}
|
|
|
|
return
|
|
}
|
|
|
|
// ReplaceIDtoID_Many - заменяет int64(ID) на ID, и остальные PrimaryKey
|
|
func ReplaceIDtoID_Many(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
TextNames, TextNamesTypes, TextProtoNames := FindTextIDMany(Table1)
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "ReplaceManyID(ID)", TextNames)
|
|
Otvet = strings.ReplaceAll(Otvet, "int64(ID)", TextProtoNames)
|
|
Otvet = strings.ReplaceAll(Otvet, "(ID int64", "("+TextNamesTypes)
|
|
Otvet = strings.ReplaceAll(Otvet, "(ID)", "("+TextNames+")")
|
|
Otvet = strings.ReplaceAll(Otvet, ", ID)", ", "+TextNames+")")
|
|
Otvet = strings.ReplaceAll(Otvet, ", ID int64)", ", "+TextNamesTypes+")")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceOtvetIDEqual1 - заменяет Otvet.ID = -1
|
|
func ReplaceOtvetIDEqual1(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//if Table1.PrimaryKeyColumnsCount == 1 {
|
|
// Otvet = ReplaceOtvetIDEqual1_1(Text, Table1)
|
|
//} else {
|
|
Otvet = ReplaceOtvetIDEqual1_ManyPK(Text, Table1)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceOtvetIDEqual1_1 - заменяет Otvet.ID = -1
|
|
func ReplaceOtvetIDEqual1_1(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
PrimaryKeyColumn := FindPrimaryKeyColumn(Table1)
|
|
if PrimaryKeyColumn == nil {
|
|
return Otvet
|
|
}
|
|
|
|
Value := FindNegativeValue(PrimaryKeyColumn.TypeGo)
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "Otvet.ID = -1", "Otvet.ID = "+Value)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceOtvetIDEqual1_ManyPK - заменяет Otvet.ID = -1
|
|
func ReplaceOtvetIDEqual1_ManyPK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
PrimaryKeyColumns := FindPrimaryKeyColumns(Table1)
|
|
if len(PrimaryKeyColumns) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
TextFind := "\tOtvet.ID = -1\n"
|
|
TextNew := ""
|
|
for _, ColumnPK1 := range PrimaryKeyColumns {
|
|
Value := FindNegativeValue(ColumnPK1.TypeGo)
|
|
TextNew = TextNew + "\tOtvet." + ColumnPK1.NameGo + " = " + Value + "\n"
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceOtvetIDEqual0 - заменяет Otvet.ID = -1
|
|
func ReplaceOtvetIDEqual0(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
ColumnsPK := FindPrimaryKeyColumns(Table1)
|
|
if len(ColumnsPK) == 0 {
|
|
return Otvet
|
|
}
|
|
|
|
//
|
|
TextFind := "\tOtvet.ID = 0\n"
|
|
TextNew := ""
|
|
for _, ColumnPK1 := range ColumnsPK {
|
|
Value := FindTextDefaultValue(ColumnPK1.TypeGo)
|
|
TextNew = TextNew + "\tOtvet." + ColumnPK1.NameGo + " = " + Value + "\n"
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
//
|
|
TextFind = " Otvet.ID == 0"
|
|
for _, ColumnPK1 := range ColumnsPK {
|
|
Value := FindTextDefaultValue(ColumnPK1.TypeGo)
|
|
TextNew = " Otvet." + ColumnPK1.NameGo + " == " + Value + ""
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
break
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceModelIDEqual1 - заменяет Otvet.ID = -1
|
|
func ReplaceModelIDEqual1(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
//if Table1.PrimaryKeyColumnsCount == 1 {
|
|
// Otvet = ReplaceModelIDEqual1_1(Otvet, Table1)
|
|
//} else {
|
|
Otvet = ReplaceModelIDEqual1_ManyPK(Otvet, Table1)
|
|
//}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
//// ReplaceModelIDEqual1 - заменяет Otvet.ID = -1
|
|
//func ReplaceModelIDEqual1_1(Text string, Table1 *types.Table) string {
|
|
// Otvet := Text
|
|
//
|
|
// PrimaryKeyColumn := FindPrimaryKeyColumn(Table1)
|
|
// if PrimaryKeyColumn == nil {
|
|
// return Otvet
|
|
// }
|
|
//
|
|
// Value := FindNegativeValue(PrimaryKeyColumn.TypeGo)
|
|
//
|
|
// Otvet = strings.ReplaceAll(Otvet, "m.ID = -1", "m.ID = "+Value)
|
|
//
|
|
// return Otvet
|
|
//}
|
|
|
|
// ReplaceModelIDEqual1_ManyPK - заменяет m.ID = -1
|
|
func ReplaceModelIDEqual1_ManyPK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
TextFind := "\tm.ID = -1\n"
|
|
TextNew := ""
|
|
MassPrimaryKey := FindPrimaryKeyColumns(Table1)
|
|
for _, Column1 := range MassPrimaryKey {
|
|
Value := FindNegativeValue(Column1.TypeGo)
|
|
TextNew = TextNew + "\tm." + Column1.NameGo + " = " + Value + "\n"
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, TextFind, TextNew)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindNegativeValue - возвращает -1 для числовых типов
|
|
func FindNegativeValue(TypeGo string) string {
|
|
Otvet := ""
|
|
|
|
Otvet = FindTextDefaultValue(TypeGo)
|
|
if mini_func.IsNumberType(TypeGo) == true {
|
|
Otvet = "-1"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindRequestFieldName - возвращает название колонки в Request
|
|
func FindRequestFieldName(Table1 *types.Table, Column1 *types.Column) string {
|
|
Otvet := ""
|
|
|
|
_, Otvet, _, _ = FindTextProtobufRequest_ID_Type(Table1, Column1, "")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceConnect_WithApplicationName - заменяет Connect_WithApplicationName() на Connect_WithApplicationName_SingularTableName()
|
|
func ReplaceConnect_WithApplicationName(Text string) string {
|
|
Otvet := Text
|
|
|
|
if config.Settings.SINGULAR_TABLE_NAMES == false {
|
|
return Otvet
|
|
}
|
|
|
|
Otvet = strings.ReplaceAll(Otvet, "postgres_gorm.Connect_WithApplicationName(", "postgres_gorm.Connect_WithApplicationName_SingularTableName(")
|
|
Otvet = strings.ReplaceAll(Otvet, "postgres_gorm.Start(", "postgres_gorm.Start_SingularTableName(")
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindTextConvertToString - возвращает имя переменной + имя колонки, преобразованное в тип string
|
|
func FindTextConvertToString(Column1 *types.Column, VariableName string) string {
|
|
Otvet := ""
|
|
|
|
if Column1 == nil {
|
|
return Otvet
|
|
}
|
|
Otvet = VariableName + "." + Column1.NameGo
|
|
switch Column1.TypeGo {
|
|
case "time.Time":
|
|
Otvet = VariableName + ".String()"
|
|
case "int64":
|
|
Otvet = "strconv.Itoa(int(" + VariableName + "))"
|
|
case "int32":
|
|
Otvet = "strconv.Itoa(int(" + VariableName + "))"
|
|
case "bool":
|
|
Otvet = "strconv.FormatBool(" + VariableName + ")"
|
|
case "float32":
|
|
Otvet = "fmt.Sprintf(%f," + VariableName + ")"
|
|
case "float64":
|
|
Otvet = "fmt.Sprintf(%f," + VariableName + ")"
|
|
case "uuid.UUID":
|
|
Otvet = VariableName + ".String()"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceCacheRemove - заменяет cache.Remove(IntFromAlias(m.ID))
|
|
func ReplaceCacheRemove(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
if Table1.PrimaryKeyColumnsCount == 1 {
|
|
Otvet = ReplaceCacheRemove_1PK(Otvet, Table1)
|
|
} else {
|
|
Otvet = ReplaceCacheRemove_ManyPK(Otvet, Table1)
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceCacheRemove1PK - заменяет cache.Remove(IntFromAlias(m.ID))
|
|
func ReplaceCacheRemove_1PK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
ColumnPK := FindPrimaryKeyColumn(Table1)
|
|
TextOld := "cache.Remove(IntFromAlias(m.ID))"
|
|
Value := ConvertFromAlias(Table1, ColumnPK, "m")
|
|
TextNew := "cache.Remove(" + Value + ")"
|
|
Otvet = strings.ReplaceAll(Otvet, TextOld, TextNew)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceCacheRemove_ManyPK - заменяет cache.Remove(IntFromAlias(m.ID)) на cache.Remove(m.StringIdentifier())
|
|
func ReplaceCacheRemove_ManyPK(Text string, Table1 *types.Table) string {
|
|
Otvet := Text
|
|
|
|
if Table1.PrimaryKeyColumnsCount > 1 {
|
|
TextOld := "cache.Remove(IntFromAlias(m.ID))"
|
|
TextNames, _, _ := FindTextID_VariableName_Many(Table1, "m")
|
|
TextNew := "cache.Remove(" + Table1.Name + ".StringIdentifier(" + TextNames + "))"
|
|
Otvet = strings.ReplaceAll(Otvet, TextOld, TextNew)
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// IsPrimaryKeyColumn - проверяет является ли колонка PrimaryKey
|
|
func IsPrimaryKeyColumn(Table1 *types.Table, Column *types.Column) bool {
|
|
Otvet := false
|
|
|
|
for _, Column1 := range Table1.MapColumns {
|
|
if Column1.IsPrimaryKey == true && Column1 == Column {
|
|
Otvet = true
|
|
break
|
|
}
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceColumnNameM - заменяет "ReplaceColumnNameM(m.ID)" на "m.ID"
|
|
func ReplaceColumnNameM(Text string, Column *types.Column) string {
|
|
Otvet := Text
|
|
|
|
TextNew := "m." + Column.Name
|
|
Otvet = strings.ReplaceAll(Otvet, "ReplaceColumnNameM(m.ID)", TextNew)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ReplaceIntFromProtoRequest - заменяет "IntFromProto(Request.ID)" на "Request.ID"
|
|
func ReplaceIntFromProtoRequest(Text string, Table1 *types.Table, Column *types.Column) string {
|
|
Otvet := Text
|
|
|
|
Variable, Golang_code := ConvertProtobufVariableToGolangVariable(Table1, Column, "Request.")
|
|
TextNew := "Request." + Variable
|
|
if Golang_code != "" {
|
|
|
|
}
|
|
Otvet = strings.ReplaceAll(Otvet, "IntFromProto(Request.ID)", TextNew)
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindRequestFieldName_FromMass - возвращает имя поля для Request protobuf
|
|
func FindRequestFieldName_FromMass(Column *types.Column, MassColumns []*types.Column) string {
|
|
Otvet := ""
|
|
|
|
TypeProto := ConvertGolangTypeNameToProtobufTypeName(Column.TypeGo)
|
|
|
|
Number := 0
|
|
for _, Column1 := range MassColumns {
|
|
TypeProto1 := ConvertGolangTypeNameToProtobufTypeName(Column1.TypeGo)
|
|
if TypeProto == TypeProto1 {
|
|
Number = Number + 1
|
|
}
|
|
|
|
if Column == Column1 {
|
|
break
|
|
}
|
|
|
|
}
|
|
Suffix := "_" + strconv.Itoa(Number)
|
|
|
|
Otvet = ConvertGolangTypeNameToProtobufFieldName(Column.Type)
|
|
Otvet = Otvet + Suffix
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertGolangTypeNameToProtobufFieldName - возвращает имя поля для protobuf
|
|
func ConvertGolangTypeNameToProtobufFieldName(TypeGo string) string {
|
|
Otvet := ""
|
|
|
|
switch TypeGo {
|
|
case "time.Time":
|
|
Otvet = "Date"
|
|
case "string":
|
|
Otvet = "String"
|
|
case "int64", "int":
|
|
Otvet = "Int64"
|
|
case "int32":
|
|
Otvet = "Int32"
|
|
case "int16":
|
|
Otvet = "Int32"
|
|
case "int8":
|
|
Otvet = "Int32"
|
|
case "uint64":
|
|
Otvet = "Uint64"
|
|
case "uint32":
|
|
Otvet = "Uint32"
|
|
case "uint16":
|
|
Otvet = "Uint32"
|
|
case "uint8":
|
|
Otvet = "Uint32"
|
|
case "bool":
|
|
Otvet = "Bool"
|
|
case "float32":
|
|
Otvet = "Float32"
|
|
case "float64":
|
|
Otvet = "Float64"
|
|
case "uuid.UUID":
|
|
Otvet = "String"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertGolangTypeNameToProtobufTypeName - возвращает имя типа для protobuf
|
|
func ConvertGolangTypeNameToProtobufTypeName(TypeGo string) string {
|
|
Otvet := ""
|
|
|
|
switch TypeGo {
|
|
case "time.Time":
|
|
Otvet = "google.protobuf.Timestamp"
|
|
case "string":
|
|
Otvet = "string"
|
|
case "int64", "int":
|
|
Otvet = "int64"
|
|
case "int32":
|
|
Otvet = "int32"
|
|
case "uint64":
|
|
Otvet = "uint64"
|
|
case "uint32":
|
|
Otvet = "uint32"
|
|
case "byte":
|
|
Otvet = "uint32"
|
|
case "[]byte":
|
|
Otvet = "bytes"
|
|
case "bool":
|
|
Otvet = "bool"
|
|
case "float32":
|
|
Otvet = "float"
|
|
case "float64":
|
|
Otvet = "double"
|
|
case "uuid.UUID":
|
|
Otvet = "string"
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// FindMassColumns_from_MassColumnsString - преобразует массив строк названий колонок в массив столбцов
|
|
func FindMassColumns_from_MassColumnsString(Table1 *types.Table, MassColumnsString []string) []*types.Column {
|
|
Otvet := make([]*types.Column, len(MassColumnsString))
|
|
|
|
for i, ColumnName := range MassColumnsString {
|
|
Column1, ok := Table1.MapColumns[ColumnName]
|
|
if ok == false {
|
|
log.Panic(Table1.Name + " .MapColumns[" + ColumnName + "] = false")
|
|
}
|
|
Otvet[i] = Column1
|
|
}
|
|
return Otvet
|
|
}
|
|
|
|
// FindMassTableColumns - преобразует TableColumns_String в TableColumns
|
|
func FindMassTableColumns(MapAll map[string]*types.Table, MassTableColumns_String []types.TableColumns_String) []types.TableColumns {
|
|
Otvet := make([]types.TableColumns, 0)
|
|
|
|
for _, TableColumns_string1 := range MassTableColumns_String {
|
|
Table1, ok := MapAll[TableColumns_string1.TableName]
|
|
if ok == false {
|
|
log.Panic(" Error: not found table: ", TableColumns_string1.TableName)
|
|
}
|
|
Columns1 := FindMassColumns_from_MassColumnsString(Table1, TableColumns_string1.MassColumnNames)
|
|
TableColumns1 := types.TableColumns{}
|
|
TableColumns1.Table = Table1
|
|
TableColumns1.Columns = Columns1
|
|
Otvet = append(Otvet, TableColumns1)
|
|
}
|
|
|
|
return Otvet
|
|
}
|
|
|
|
// ConvertProtobufVariableToGolangVariable_with_MassColumns - возвращает имя переменной + имя колонки, преобразованное в тип golang из protobuf
|
|
func ConvertProtobufVariableToGolangVariable_with_MassColumns(Column *types.Column, MassColumns []*types.Column, VariableName string) (VariableField string, GolangCode string) {
|
|
RequestFieldName := FindRequestFieldName_FromMass(Column, MassColumns)
|
|
VariableField = VariableName + RequestFieldName
|
|
|
|
switch Column.TypeGo {
|
|
case "time.Time":
|
|
{
|
|
VariableField = VariableName + RequestFieldName + ".AsTime()"
|
|
return VariableField, GolangCode
|
|
}
|
|
case "uuid.UUID":
|
|
{
|
|
VariableField = "uuid.FromBytes([]byte(" + VariableName + RequestFieldName + "))"
|
|
GolangCode = Column.NameGo + `, err := uuid.FromBytes([]byte(Request.` + RequestFieldName + `))
|
|
if err != nil {
|
|
return &Otvet, err
|
|
}
|
|
`
|
|
return VariableField, GolangCode
|
|
}
|
|
}
|
|
|
|
return VariableField, GolangCode
|
|
}
|
|
|
|
// FindRequestFieldNames_FromMass - возвращает строку с именами колонок для Protobuf
|
|
func FindRequestFieldNames_FromMass(MassColumns []*types.Column) string {
|
|
Otvet := ""
|
|
|
|
TextFields := ""
|
|
TextRequest := ""
|
|
Underline := ""
|
|
for _, Column1 := range MassColumns {
|
|
TextFields = TextFields + Underline + Column1.NameGo
|
|
TextRequest1 := FindRequestFieldName_FromMass(Column1, MassColumns)
|
|
TextRequest = TextRequest + Underline + TextRequest1
|
|
Underline = "_"
|
|
}
|
|
|
|
return Otvet
|
|
}
|