mirror of
https://github.com/memohai/Memoh.git
synced 2026-04-25 07:00:48 +09:00
0e646625bf
Allow users to configure what percentage of older messages to compact, keeping the most recent portion intact. Default ratio is 80%, meaning the oldest 80% of uncompacted messages are summarized while the newest 20% remain as-is for full-fidelity context.
42 lines
1.2 KiB
Go
42 lines
1.2 KiB
Go
package compaction
|
|
|
|
import (
|
|
"net/http"
|
|
"time"
|
|
)
|
|
|
|
// Log represents a compaction log entry.
|
|
type Log struct {
|
|
ID string `json:"id"`
|
|
BotID string `json:"bot_id"`
|
|
SessionID string `json:"session_id,omitempty"`
|
|
Status string `json:"status"`
|
|
Summary string `json:"summary"`
|
|
MessageCount int `json:"message_count"`
|
|
ErrorMessage string `json:"error_message"`
|
|
Usage any `json:"usage,omitempty"`
|
|
ModelID string `json:"model_id,omitempty"`
|
|
StartedAt time.Time `json:"started_at"`
|
|
CompletedAt *time.Time `json:"completed_at,omitempty"`
|
|
}
|
|
|
|
// ListLogsResponse is the API response for listing compaction logs.
|
|
type ListLogsResponse struct {
|
|
Items []Log `json:"items"`
|
|
TotalCount int64 `json:"total_count"`
|
|
}
|
|
|
|
// TriggerConfig holds the parameters needed to trigger a compaction.
|
|
type TriggerConfig struct {
|
|
BotID string
|
|
SessionID string
|
|
ModelID string
|
|
ClientType string
|
|
APIKey string //nolint:gosec // runtime credential, not a hardcoded secret
|
|
CodexAccountID string
|
|
BaseURL string
|
|
HTTPClient *http.Client
|
|
Ratio int
|
|
TotalInputTokens int
|
|
}
|