Files
atahango/internal/services/resume_service.go
Beyhan Oğur bbbf76b184 first commit
2026-04-26 21:35:24 +03:00

185 lines
5.0 KiB
Go

package services
import (
"errors"
"gauth-central/internal/database"
"gauth-central/internal/models"
"gorm.io/gorm"
)
type ResumeService struct{}
func NewResumeService() *ResumeService {
return &ResumeService{}
}
// CreateResume creates a new resume configuration.
func (s *ResumeService) CreateResume(title, titleSub, education, experience, codingSkills, knowledge string, isActive bool) (*models.Resume, error) {
item := models.Resume{
Title: title,
TitleSub: titleSub,
Education: education,
Experience: experience,
CodingSkills: codingSkills,
Knowledge: knowledge,
IsActive: isActive,
}
err := database.DB.Transaction(func(tx *gorm.DB) error {
if isActive {
// Deactivate all other resumes
if err := tx.Model(&models.Resume{}).Where("is_active = ?", true).Update("is_active", false).Error; err != nil {
return err
}
}
if err := tx.Create(&item).Error; err != nil {
return err
}
return nil
})
if err != nil {
return nil, err
}
return s.GetResumeByID(item.ID.String())
}
// GetAllResumes retrieves all resumes. Use onlyActive to filter public data.
// For admin (onlyActive=false), it returns basic info.
// For public (onlyActive=true), it preloads all related data (Educations, Experiences, etc.)
func (s *ResumeService) GetAllResumes(onlyActive bool) ([]models.Resume, error) {
var items []models.Resume
query := database.DB.Order("created_at desc")
if onlyActive {
query = query.Where("is_active = ?", true).
Preload("Educations", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("created_at desc")
}).
Preload("Experiences", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("created_at desc")
}).
Preload("Skills", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("degree desc")
}).
Preload("Knowledges", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("created_at desc")
})
}
if err := query.Find(&items).Error; err != nil {
return nil, err
}
return items, nil
}
// GetFirstActiveResume returns the single active resume with all relations preloaded.
func (s *ResumeService) GetFirstActiveResume() (*models.Resume, error) {
var item models.Resume
query := database.DB.Where("is_active = ?", true).Order("created_at desc").
Preload("Educations", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("created_at desc")
}).
Preload("Experiences", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("created_at desc")
}).
Preload("Skills", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("degree desc")
}).
Preload("Knowledges", func(db *gorm.DB) *gorm.DB {
return db.Where("is_active = ?", true).Order("created_at desc")
})
if err := query.First(&item).Error; err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
return nil, errors.New("resume not found")
}
return nil, err
}
return &item, nil
}
// GetResumeByID retrieves a resume by ID.
func (s *ResumeService) GetResumeByID(id string) (*models.Resume, error) {
var item models.Resume
if err := database.DB.Where("id = ?", id).
Preload("Educations").
Preload("Experiences").
Preload("Skills").
Preload("Knowledges").
First(&item).Error; err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) {
return nil, errors.New("resume not found")
}
return nil, err
}
return &item, nil
}
// UpdateResume updates an existing resume entry.
func (s *ResumeService) UpdateResume(id string, title, titleSub, education, experience, codingSkills, knowledge *string, isActive *bool) (*models.Resume, error) {
item, err := s.GetResumeByID(id)
if err != nil {
return nil, err
}
updates := map[string]interface{}{}
if title != nil {
updates["title"] = *title
}
if titleSub != nil {
updates["title_sub"] = *titleSub
}
if education != nil {
updates["education"] = *education
}
if experience != nil {
updates["experience"] = *experience
}
if codingSkills != nil {
updates["coding_skills"] = *codingSkills
}
if knowledge != nil {
updates["knowledge"] = *knowledge
}
if isActive != nil {
updates["is_active"] = *isActive
}
if len(updates) > 0 {
err := database.DB.Transaction(func(tx *gorm.DB) error {
if isActive != nil && *isActive {
// Deactivate all other resumes except the current one
if err := tx.Model(&models.Resume{}).Where("id != ? AND is_active = ?", id, true).Update("is_active", false).Error; err != nil {
return err
}
}
if err := tx.Model(item).Updates(updates).Error; err != nil {
return err
}
return nil
})
if err != nil {
return nil, err
}
}
return s.GetResumeByID(id)
}
// DeleteResume deletes a resume by ID.
func (s *ResumeService) DeleteResume(id string) error {
result := database.DB.Delete(&models.Resume{}, "id = ?", id)
if result.Error != nil {
return result.Error
}
if result.RowsAffected == 0 {
return errors.New("resume not found")
}
return nil
}