-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathevent_end.go
91 lines (78 loc) · 2.42 KB
/
event_end.go
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/*
Copyright 2023 The bpmn Authors
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library;
*/
package bpmn
import (
"context"
"github.com/olive-io/bpmn/schema"
"github.com/olive-io/bpmn/v2/pkg/event"
"github.com/olive-io/bpmn/v2/pkg/tracing"
)
type EndEvent struct {
*Wiring
element *schema.EndEvent
activated bool
completed bool
mch chan imessage
startEventsActivated []*schema.StartEvent
}
func NewEndEvent(ctx context.Context, wiring *Wiring, endEvent *schema.EndEvent) (evt *EndEvent, err error) {
evt = &EndEvent{
Wiring: wiring,
element: endEvent,
activated: false,
completed: false,
mch: make(chan imessage, len(wiring.Incoming)*2+1),
startEventsActivated: make([]*schema.StartEvent, 0),
}
sender := evt.Tracer.RegisterSender()
go evt.run(ctx, sender)
return
}
func (evt *EndEvent) run(ctx context.Context, sender tracing.ISenderHandle) {
defer sender.Done()
for {
select {
case msg := <-evt.mch:
switch m := msg.(type) {
case nextActionMessage:
if !evt.activated {
evt.activated = true
}
// If the node already completed, then we essentially fuse it
if evt.completed {
m.response <- CompleteAction{}
continue
}
if _, err := evt.EventIngress.ConsumeEvent(event.MakeEndEvent(evt.element)); err == nil {
evt.completed = true
m.response <- CompleteAction{}
} else {
evt.Wiring.Tracer.Trace(ErrorTrace{Error: err})
}
default:
}
case <-ctx.Done():
evt.Tracer.Trace(CancellationFlowNodeTrace{Node: evt.element})
return
}
}
}
func (evt *EndEvent) NextAction(T) chan IAction {
response := make(chan IAction, 1)
evt.mch <- nextActionMessage{response: response}
return response
}
func (evt *EndEvent) Element() schema.FlowNodeInterface {
return evt.element
}