-
Notifications
You must be signed in to change notification settings - Fork 570
Expand file tree
/
Copy pathDeploymentEventHandler.go
More file actions
75 lines (66 loc) · 2.76 KB
/
DeploymentEventHandler.go
File metadata and controls
75 lines (66 loc) · 2.76 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
* Copyright (c) 2020 Devtron Labs
*
* 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 app
import (
"strings"
"time"
"github.com/devtron-labs/devtron/api/bean"
"github.com/devtron-labs/devtron/client/argocdServer/application"
client "github.com/devtron-labs/devtron/client/events"
"github.com/devtron-labs/devtron/internal/sql/repository"
util "github.com/devtron-labs/devtron/util/event"
"go.uber.org/zap"
)
type DeploymentEventHandler interface {
WriteCDDeploymentEvent(pipelineId, appId, envId int, eventType util.EventType)
}
type DeploymentEventHandlerImpl struct {
logger *zap.SugaredLogger
appListingService AppListingService
eventFactory client.EventFactory
eventClient client.EventClient
}
func NewDeploymentEventHandlerImpl(logger *zap.SugaredLogger, appListingService AppListingService, eventClient client.EventClient, eventFactory client.EventFactory) *DeploymentEventHandlerImpl {
deploymentEventHandlerImpl := &DeploymentEventHandlerImpl{
logger: logger,
appListingService: appListingService,
eventClient: eventClient,
eventFactory: eventFactory,
}
return deploymentEventHandlerImpl
}
func (impl *DeploymentEventHandlerImpl) WriteCDDeploymentEvent(pipelineId, appId, envId int, eventType util.EventType) {
event := impl.eventFactory.Build(eventType, &pipelineId, appId, &envId, util.CD)
impl.logger.Debugw("event WriteCDDeploymentEvent", "event", event)
event = impl.eventFactory.BuildExtraCDData(event, nil, 0, bean.CD_WORKFLOW_TYPE_DEPLOY)
_, evtErr := impl.eventClient.WriteNotificationEvent(event)
if evtErr != nil {
impl.logger.Errorw("error in writing event", "err", evtErr)
}
}
func (impl *DeploymentEventHandlerImpl) BuildPayload(appName string, deploymentFailureTime time.Time) *client.Payload {
applicationName := appName[:strings.LastIndex(appName, "-")]
evnName := appName[strings.LastIndex(appName, "-")+1:]
payload := &client.Payload{}
payload.AppName = applicationName
payload.EnvName = evnName
//payload["deploymentFailureTime"] = deploymentFailureTime.Format(bean.LayoutRFC3339)
return payload
}
func (impl *DeploymentEventHandlerImpl) isDeploymentFailed(ds repository.DeploymentStatus) bool {
return ds.Status == application.Degraded && time.Since(ds.UpdatedOn) > 5*time.Minute
}