124 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Go
		
	
	
	
/*
 | 
						|
 * Copyright 2025 coze-dev Authors
 | 
						|
 *
 | 
						|
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
 * you may not use this file except in compliance with the License.
 | 
						|
 * You may obtain a copy of the License at
 | 
						|
 *
 | 
						|
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 *
 | 
						|
 * Unless required by applicable law or agreed to in writing, software
 | 
						|
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
 * See the License for the specific language governing permissions and
 | 
						|
 * limitations under the License.
 | 
						|
 */
 | 
						|
 | 
						|
package internal
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/cloudwego/eino/schema"
 | 
						|
 | 
						|
	"github.com/coze-dev/coze-studio/backend/api/model/crossdomain/agentrun"
 | 
						|
	"github.com/coze-dev/coze-studio/backend/domain/conversation/agentrun/entity"
 | 
						|
	"github.com/coze-dev/coze-studio/backend/domain/conversation/agentrun/repository"
 | 
						|
	"github.com/coze-dev/coze-studio/backend/pkg/logs"
 | 
						|
	"github.com/coze-dev/coze-studio/backend/types/errno"
 | 
						|
)
 | 
						|
 | 
						|
type RunProcess struct {
 | 
						|
	event *Event
 | 
						|
 | 
						|
	RunRecordRepo repository.RunRecordRepo
 | 
						|
}
 | 
						|
 | 
						|
func NewRunProcess(runRecordRepo repository.RunRecordRepo) *RunProcess {
 | 
						|
	return &RunProcess{
 | 
						|
		RunRecordRepo: runRecordRepo,
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (r *RunProcess) StepToCreate(ctx context.Context, srRecord *entity.ChunkRunItem, sw *schema.StreamWriter[*entity.AgentRunResponse]) {
 | 
						|
	srRecord.Status = entity.RunStatusCreated
 | 
						|
	r.event.SendRunEvent(entity.RunEventCreated, srRecord, sw)
 | 
						|
}
 | 
						|
func (r *RunProcess) StepToInProgress(ctx context.Context, srRecord *entity.ChunkRunItem, sw *schema.StreamWriter[*entity.AgentRunResponse]) error {
 | 
						|
	srRecord.Status = entity.RunStatusInProgress
 | 
						|
 | 
						|
	updateMeta := &entity.UpdateMeta{
 | 
						|
		Status:    entity.RunStatusInProgress,
 | 
						|
		UpdatedAt: time.Now().UnixMilli(),
 | 
						|
	}
 | 
						|
	err := r.RunRecordRepo.UpdateByID(ctx, srRecord.ID, updateMeta)
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	r.event.SendRunEvent(entity.RunEventInProgress, srRecord, sw)
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func (r *RunProcess) StepToComplete(ctx context.Context, srRecord *entity.ChunkRunItem, sw *schema.StreamWriter[*entity.AgentRunResponse], usage *agentrun.Usage) {
 | 
						|
 | 
						|
	completedAt := time.Now().UnixMilli()
 | 
						|
 | 
						|
	updateMeta := &entity.UpdateMeta{
 | 
						|
		Status:      entity.RunStatusCompleted,
 | 
						|
		Usage:       usage,
 | 
						|
		CompletedAt: completedAt,
 | 
						|
		UpdatedAt:   completedAt,
 | 
						|
	}
 | 
						|
	err := r.RunRecordRepo.UpdateByID(ctx, srRecord.ID, updateMeta)
 | 
						|
	if err != nil {
 | 
						|
		logs.CtxErrorf(ctx, "RunRecordRepo.UpdateByID error: %v", err)
 | 
						|
		r.event.SendErrEvent(entity.RunEventError, sw, &entity.RunError{
 | 
						|
			Code: errno.ErrConversationAgentRunError,
 | 
						|
			Msg:  err.Error(),
 | 
						|
		})
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	srRecord.CompletedAt = completedAt
 | 
						|
	srRecord.Status = entity.RunStatusCompleted
 | 
						|
 | 
						|
	r.event.SendRunEvent(entity.RunEventCompleted, srRecord, sw)
 | 
						|
 | 
						|
	r.event.SendStreamDoneEvent(sw)
 | 
						|
}
 | 
						|
func (r *RunProcess) StepToFailed(ctx context.Context, srRecord *entity.ChunkRunItem, sw *schema.StreamWriter[*entity.AgentRunResponse]) {
 | 
						|
 | 
						|
	nowTime := time.Now().UnixMilli()
 | 
						|
	updateMeta := &entity.UpdateMeta{
 | 
						|
		Status:    entity.RunStatusFailed,
 | 
						|
		UpdatedAt: nowTime,
 | 
						|
		FailedAt:  nowTime,
 | 
						|
		LastError: srRecord.Error,
 | 
						|
	}
 | 
						|
 | 
						|
	err := r.RunRecordRepo.UpdateByID(ctx, srRecord.ID, updateMeta)
 | 
						|
 | 
						|
	if err != nil {
 | 
						|
		r.event.SendErrEvent(entity.RunEventError, sw, &entity.RunError{
 | 
						|
			Code: errno.ErrConversationAgentRunError,
 | 
						|
			Msg:  err.Error(),
 | 
						|
		})
 | 
						|
		logs.CtxErrorf(ctx, "update run record failed, err: %v", err)
 | 
						|
		return
 | 
						|
	}
 | 
						|
	srRecord.Status = entity.RunStatusFailed
 | 
						|
	srRecord.FailedAt = time.Now().UnixMilli()
 | 
						|
	r.event.SendErrEvent(entity.RunEventError, sw, &entity.RunError{
 | 
						|
		Code: srRecord.Error.Code,
 | 
						|
		Msg:  srRecord.Error.Msg,
 | 
						|
	})
 | 
						|
	return
 | 
						|
}
 | 
						|
 | 
						|
func (r *RunProcess) StepToDone(sw *schema.StreamWriter[*entity.AgentRunResponse]) {
 | 
						|
	r.event.SendStreamDoneEvent(sw)
 | 
						|
}
 |