Add authentication server, dev CLI, Docker multi-service setup, and cross-platform improvements

This commit is contained in:
Ilya Groshev
2026-04-21 16:49:44 +03:00
parent 43d6527b42
commit a3fbb1aeba
121 changed files with 4523 additions and 2888 deletions
+1 -28
View File
@@ -2,12 +2,10 @@ package service
import (
"context"
"encoding/json"
"fmt"
"log"
pb "lunar-tear/server/gen/proto"
"lunar-tear/server/internal/gametime"
"lunar-tear/server/internal/masterdata"
"lunar-tear/server/internal/store"
@@ -28,7 +26,7 @@ func NewCharacterViewerServiceServer(users store.UserRepository, sessions store.
func (s *CharacterViewerServiceServer) CharacterViewerTop(ctx context.Context, _ *emptypb.Empty) (*pb.CharacterViewerTopResponse, error) {
log.Printf("[CharacterViewerService] CharacterViewerTop")
userId := currentUserId(ctx, s.users, s.sessions)
userId := CurrentUserId(ctx, s.users, s.sessions)
user, err := s.users.LoadUser(userId)
if err != nil {
panic(fmt.Sprintf("CharacterViewerTop: no user for userId=%d: %v", userId, err))
@@ -37,32 +35,7 @@ func (s *CharacterViewerServiceServer) CharacterViewerTop(ctx context.Context, _
released := s.catalog.ReleasedFieldIds(user)
log.Printf("[CharacterViewerService] released %d fields for user %d", len(released), userId)
now := gametime.NowMillis()
records := make([]map[string]any, 0, len(released))
for _, fieldId := range released {
records = append(records, map[string]any{
"userId": userId,
"characterViewerFieldId": fieldId,
"releaseDatetime": now,
"latestVersion": 0,
})
}
payload := "[]"
if len(records) > 0 {
data, _ := json.Marshal(records)
payload = string(data)
}
diff := map[string]*pb.DiffData{
"IUserCharacterViewerField": {
UpdateRecordsJson: payload,
DeleteKeysJson: "[]",
},
}
return &pb.CharacterViewerTopResponse{
ReleaseCharacterViewerFieldId: released,
DiffUserData: diff,
}, nil
}