package logger

import (
	"encoding/json"
	"fmt"
	"os"
	"sync"
	"time"
)

// FailureLog represents a logged failure
type FailureLog struct {
	Timestamp string `json:"timestamp"`
	Task      string `json:"task"`
	Endpoint  string `json:"endpoint"`
	Error     string `json:"error"`
	Details   string `json:"details,omitempty"`
}

// Logger handles failure logging to JSONL file
type Logger struct {
	mu      sync.Mutex
	file    *os.File
	encoder *json.Encoder
}

// NewLogger creates a new failure logger
func NewLogger(filepath string) (*Logger, error) {
	file, err := os.OpenFile(filepath, os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0644)
	if err != nil {
		return nil, fmt.Errorf("failed to open log file: %w", err)
	}

	return &Logger{
		file:    file,
		encoder: json.NewEncoder(file),
	}, nil
}

// LogFailure logs a failure to the JSONL file
func (l *Logger) LogFailure(task, endpoint, error, details string) {
	l.mu.Lock()
	defer l.mu.Unlock()

	entry := FailureLog{
		Timestamp: time.Now().Format(time.RFC3339),
		Task:      task,
		Endpoint:  endpoint,
		Error:     error,
		Details:   details,
	}

	if err := l.encoder.Encode(entry); err != nil {
		fmt.Printf("[ERROR] Failed to write to failure log: %v\n", err)
	}
}

// Close closes the log file
func (l *Logger) Close() error {
	l.mu.Lock()
	defer l.mu.Unlock()
	return l.file.Close()
}
