mirror of
https://github.com/lordmathis/lemma.git
synced 2025-11-07 00:14:25 +00:00
Use InsertStruct
This commit is contained in:
@@ -10,11 +10,12 @@ import (
|
||||
|
||||
// CreateSession inserts a new session record into the database
|
||||
func (db *database) CreateSession(session *models.Session) error {
|
||||
query := NewQuery(db.dbType).
|
||||
Insert("sessions", "id", "user_id", "refresh_token", "expires_at", "created_at").
|
||||
Values(5).
|
||||
AddArgs(session.ID, session.UserID, session.RefreshToken, session.ExpiresAt, session.CreatedAt)
|
||||
_, err := db.Exec(query.String(), query.Args()...)
|
||||
query, err := NewQuery(db.dbType).
|
||||
InsertStruct(session, "sessions")
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create query: %w", err)
|
||||
}
|
||||
_, err = db.Exec(query.String(), query.Args()...)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to store session: %w", err)
|
||||
}
|
||||
|
||||
@@ -8,9 +8,10 @@ import (
|
||||
)
|
||||
|
||||
type DBField struct {
|
||||
Name string
|
||||
Value any
|
||||
Type reflect.Type
|
||||
Name string
|
||||
Value any
|
||||
Type reflect.Type
|
||||
useDefault bool
|
||||
}
|
||||
|
||||
func StructTagsToFields(s any) ([]DBField, error) {
|
||||
@@ -47,14 +48,28 @@ func StructTagsToFields(s any) ([]DBField, error) {
|
||||
tag = toSnakeCase(f.Name)
|
||||
}
|
||||
|
||||
if strings.Contains(tag, "omitempty") && reflect.DeepEqual(v.Field(i).Interface(), reflect.Zero(f.Type).Interface()) {
|
||||
continue
|
||||
useDefault := false
|
||||
if strings.Contains(tag, ",") {
|
||||
parts := strings.Split(tag, ",")
|
||||
tag = parts[0]
|
||||
|
||||
for _, opt := range parts[1:] {
|
||||
switch opt {
|
||||
case "omitempty":
|
||||
if reflect.DeepEqual(v.Field(i).Interface(), reflect.Zero(f.Type).Interface()) {
|
||||
continue
|
||||
}
|
||||
case "default":
|
||||
useDefault = true
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fields = append(fields, DBField{
|
||||
Name: tag,
|
||||
Value: v.Field(i).Interface(),
|
||||
Type: f.Type,
|
||||
Name: tag,
|
||||
Value: v.Field(i).Interface(),
|
||||
Type: f.Type,
|
||||
useDefault: useDefault,
|
||||
})
|
||||
}
|
||||
return fields, nil
|
||||
@@ -86,6 +101,10 @@ func (q *Query) InsertStruct(s any, table string) (*Query, error) {
|
||||
values := make([]any, 0, len(fields))
|
||||
|
||||
for _, f := range fields {
|
||||
if f.useDefault {
|
||||
continue
|
||||
}
|
||||
|
||||
columns = append(columns, f.Name)
|
||||
values = append(values, f.Value)
|
||||
}
|
||||
|
||||
@@ -17,11 +17,14 @@ func (db *database) CreateUser(user *models.User) (*models.User, error) {
|
||||
}
|
||||
defer tx.Rollback()
|
||||
|
||||
query := NewQuery(db.dbType).
|
||||
Insert("users", "email", "display_name", "password_hash", "role").
|
||||
Values(4).
|
||||
AddArgs(user.Email, user.DisplayName, user.PasswordHash, user.Role).
|
||||
Returning("id", "created_at")
|
||||
query, err := NewQuery(db.dbType).
|
||||
InsertStruct(user, "users")
|
||||
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to create query: %w", err)
|
||||
}
|
||||
|
||||
query.Returning("id", "created_at")
|
||||
|
||||
err = tx.QueryRow(query.String(), query.Args()...).
|
||||
Scan(&user.ID, &user.CreatedAt)
|
||||
@@ -69,23 +72,16 @@ func (db *database) CreateUser(user *models.User) (*models.User, error) {
|
||||
func (db *database) createWorkspaceTx(tx *sql.Tx, workspace *models.Workspace) error {
|
||||
log := getLogger().WithGroup("users")
|
||||
|
||||
insertQuery := NewQuery(db.dbType).
|
||||
Insert("workspaces",
|
||||
"user_id", "name",
|
||||
"theme", "auto_save", "show_hidden_files",
|
||||
"git_enabled", "git_url", "git_user", "git_token",
|
||||
"git_auto_commit", "git_commit_msg_template",
|
||||
"git_commit_name", "git_commit_email").
|
||||
Values(13).
|
||||
AddArgs(
|
||||
workspace.UserID, workspace.Name,
|
||||
workspace.Theme, workspace.AutoSave, workspace.ShowHiddenFiles,
|
||||
workspace.GitEnabled, workspace.GitURL, workspace.GitUser, workspace.GitToken,
|
||||
workspace.GitAutoCommit, workspace.GitCommitMsgTemplate,
|
||||
workspace.GitCommitName, workspace.GitCommitEmail).
|
||||
Returning("id")
|
||||
insertQuery, err := NewQuery(db.dbType).
|
||||
InsertStruct(workspace, "workspaces")
|
||||
|
||||
err := tx.QueryRow(insertQuery.String(), insertQuery.Args()...).Scan(&workspace.ID)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create query: %w", err)
|
||||
}
|
||||
|
||||
insertQuery.Returning("id")
|
||||
|
||||
err = tx.QueryRow(insertQuery.String(), insertQuery.Args()...).Scan(&workspace.ID)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to insert workspace: %w", err)
|
||||
}
|
||||
|
||||
@@ -24,19 +24,16 @@ func (db *database) CreateWorkspace(workspace *models.Workspace) error {
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to encrypt token: %w", err)
|
||||
}
|
||||
workspace.GitToken = encryptedToken
|
||||
|
||||
query := NewQuery(db.dbType).
|
||||
Insert("workspaces",
|
||||
"user_id", "name", "theme", "auto_save", "show_hidden_files",
|
||||
"git_enabled", "git_url", "git_user", "git_token",
|
||||
"git_auto_commit", "git_commit_msg_template",
|
||||
"git_commit_name", "git_commit_email").
|
||||
Values(13).
|
||||
AddArgs(
|
||||
workspace.UserID, workspace.Name, workspace.Theme, workspace.AutoSave, workspace.ShowHiddenFiles,
|
||||
workspace.GitEnabled, workspace.GitURL, workspace.GitUser, encryptedToken,
|
||||
workspace.GitAutoCommit, workspace.GitCommitMsgTemplate, workspace.GitCommitName, workspace.GitCommitEmail).
|
||||
Returning("id", "created_at")
|
||||
query, err := NewQuery(db.dbType).
|
||||
InsertStruct(workspace, "workspaces")
|
||||
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to create query: %w", err)
|
||||
}
|
||||
|
||||
query.Returning("id", "created_at")
|
||||
|
||||
err = db.QueryRow(query.String(), query.Args()...).
|
||||
Scan(&workspace.ID, &workspace.CreatedAt)
|
||||
|
||||
Reference in New Issue
Block a user