1
0
forked from baron/baron-sso

feat(user): support fixed UUID registration and enhance bulk import results

- Added support for fixed UUIDs during bulk registration (Search-first + ExternalID mapping)
- Implemented idempotency and visibility restoration for soft-deleted users
- Enhanced bulk upload UI to show 'New/Updated/Unchanged' status and modified fields
- Added logic to reclaim identifiers (login_id) from colliding records
- Added frontend E2E and backend unit tests for UUID integrity and conflict handling
- Fixed i18n, formatting, and mock tests to satisfy code-check
- Applied 'go fix' for 'omitzero' tags and general Go standards
This commit is contained in:
2026-06-01 15:34:08 +09:00
parent 4a1e89e421
commit 31d107ff2e
85 changed files with 2104 additions and 1149 deletions

View File

@@ -33,7 +33,7 @@ func MaskSensitiveJSON(data []byte) []byte {
return data
}
var obj interface{}
var obj any
if err := json.Unmarshal(data, &obj); err != nil {
// Not a JSON object/array, return as is
return data
@@ -48,10 +48,10 @@ func MaskSensitiveJSON(data []byte) []byte {
return result
}
func maskValue(v interface{}) interface{} {
func maskValue(v any) any {
switch val := v.(type) {
case map[string]interface{}:
newMap := make(map[string]interface{}, len(val))
case map[string]any:
newMap := make(map[string]any, len(val))
for k, v := range val {
if isSensitive(k) {
newMap[k] = "*****"
@@ -60,8 +60,8 @@ func maskValue(v interface{}) interface{} {
}
}
return newMap
case []interface{}:
newArr := make([]interface{}, len(val))
case []any:
newArr := make([]any, len(val))
for i, v := range val {
newArr[i] = maskValue(v)
}

View File

@@ -4,6 +4,8 @@ import (
"baron-sso-backend/internal/domain"
"crypto/rand"
"fmt"
"slices"
"strings"
)
const (
@@ -111,13 +113,7 @@ func GeneratePasswordWithPolicy(policy *domain.PasswordPolicy) (string, error) {
if additionalTypes > 0 {
pool := make([]string, 0, len(selected))
for _, cat := range selected {
isRequired := false
for _, req := range required {
if req == cat {
isRequired = true
break
}
}
isRequired := slices.Contains(required, cat)
if !isRequired {
pool = append(pool, cat)
}
@@ -150,12 +146,12 @@ func GeneratePasswordWithPolicy(policy *domain.PasswordPolicy) (string, error) {
passwordRunes = append(passwordRunes, ch)
}
combined := ""
var combined strings.Builder
for _, charset := range selected {
combined += charset
combined.WriteString(charset)
}
for len(passwordRunes) < minLength {
ch, err := randomChar(combined)
ch, err := randomChar(combined.String())
if err != nil {
return "", err
}