101 lines
3.7 KiB
Go
101 lines
3.7 KiB
Go
package command
|
|
|
|
import (
|
|
"fmt"
|
|
"houston/pkg/postgres/query"
|
|
houston "houston/pkg/slack/houston/design"
|
|
|
|
"github.com/slack-go/slack"
|
|
"github.com/slack-go/slack/socketmode"
|
|
"go.uber.org/zap"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type incidentUpdateDescriptionProcessor struct {
|
|
client *socketmode.Client
|
|
db *gorm.DB
|
|
logger *zap.Logger
|
|
}
|
|
|
|
func NewIncidentUpdateDescriptionProcessor(client *socketmode.Client, db *gorm.DB, logger *zap.Logger) *incidentUpdateDescriptionProcessor {
|
|
return &incidentUpdateDescriptionProcessor{
|
|
client: client,
|
|
db: db,
|
|
logger: logger,
|
|
}
|
|
}
|
|
|
|
func (idp *incidentUpdateDescriptionProcessor) IncidentUpdateDescriptionRequestProcess(callback slack.InteractionCallback, request *socketmode.Request) {
|
|
result, err := query.FindIncidentByChannelId(idp.db, callback.Channel.ID)
|
|
if err != nil {
|
|
idp.logger.Error("FindIncidentByChannelId error ",
|
|
zap.String("incident_slack_channel_id", callback.Channel.ID), zap.String("channel", callback.Channel.Name),
|
|
zap.String("user_id", callback.User.ID), zap.Error(err))
|
|
return
|
|
} else if result == nil {
|
|
idp.logger.Error("IncidentEntity not found ",
|
|
zap.String("incident_slack_channel_id", callback.Channel.ID), zap.String("channel", callback.Channel.Name),
|
|
zap.String("user_id", callback.User.ID), zap.Error(err))
|
|
return
|
|
}
|
|
modalRequest := houston.BuildIncidentUpdateDescriptionModal(idp.db, callback.Channel, result.Description)
|
|
|
|
_, err = idp.client.OpenView(callback.TriggerID, modalRequest)
|
|
if err != nil {
|
|
idp.logger.Error("houston slack openview command for IncidentUpdateDescriptionRequestProcess failed.",
|
|
zap.String("trigger_id", callback.TriggerID), zap.String("channel_id", callback.Channel.ID), zap.Error(err))
|
|
return
|
|
}
|
|
var payload interface{}
|
|
idp.client.Ack(*request, payload)
|
|
}
|
|
|
|
func (itp *incidentUpdateDescriptionProcessor) IncidentUpdateDescription(callback slack.InteractionCallback, request *socketmode.Request, channel slack.Channel, user slack.User) {
|
|
incidentEntity, err := query.FindIncidentByChannelId(itp.db, callback.View.PrivateMetadata)
|
|
if err != nil {
|
|
itp.logger.Error("FindIncidentByChannelId error",
|
|
zap.String("incident_slack_channel_id", channel.ID), zap.String("channel", channel.Name),
|
|
zap.String("user_id", user.ID), zap.Error(err))
|
|
return
|
|
} else if incidentEntity == nil {
|
|
itp.logger.Error("IncidentEntity not found ",
|
|
zap.String("incident_slack_channel_id", callback.Channel.ID), zap.String("channel", callback.Channel.Name),
|
|
zap.String("user_id", callback.User.ID), zap.Error(err))
|
|
return
|
|
}
|
|
|
|
incidentDescription := buildUpdateIncidentDescriptionRequest(callback.View.State.Values)
|
|
|
|
incidentEntity.Description = incidentDescription
|
|
incidentEntity.UpdatedBy = user.ID
|
|
err = query.UpdateIncident(itp.db, incidentEntity)
|
|
if err != nil {
|
|
itp.logger.Error("IncidentUpdateDescription error",
|
|
zap.String("incident_slack_channel_id", channel.ID), zap.String("channel", channel.Name),
|
|
zap.String("user_id", user.ID), zap.Error(err))
|
|
return
|
|
}
|
|
msgOption := slack.MsgOptionText(fmt.Sprintf("<@%s> > set description to %s", user.ID, incidentEntity.Description), false)
|
|
_, _, errMessage := itp.client.PostMessage(callback.View.PrivateMetadata, msgOption)
|
|
if errMessage != nil {
|
|
itp.logger.Error("post response failed for IncidentUpdateDescription", zap.Error(errMessage))
|
|
return
|
|
}
|
|
|
|
var payload interface{}
|
|
itp.client.Ack(*request, payload)
|
|
}
|
|
|
|
func buildUpdateIncidentDescriptionRequest(blockActions map[string]map[string]slack.BlockAction) string {
|
|
var requestMap = make(map[string]string, 0)
|
|
for _, actions := range blockActions {
|
|
for actionID, action := range actions {
|
|
if action.Type == "plain_text_input" {
|
|
requestMap[actionID] = action.Value
|
|
}
|
|
}
|
|
}
|
|
|
|
return requestMap["incident_description"]
|
|
}
|