-
Notifications
You must be signed in to change notification settings - Fork 0
/
process_digest_api.go
123 lines (98 loc) · 2.81 KB
/
process_digest_api.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
package cmds
import (
"context"
"crypto/tls"
"github.com/pkg/errors"
currencycmds "github.com/spikeekips/mitum-currency/cmds"
"github.com/spikeekips/mitum/launch/config"
"github.com/spikeekips/mitum/launch/pm"
"github.com/spikeekips/mitum/util"
"github.com/spikeekips/mitum/util/logging"
"github.com/soonkuk/mitum-blocksign/digest"
)
const (
ProcessNameDigestAPI = "digest_api"
ProcessNameStartDigestAPI = "start_digest_api"
HookNameSetLocalChannel = "set_local_channel"
)
var (
ProcessorDigestAPI pm.Process
ProcessorStartDigestAPI pm.Process
)
func init() {
if i, err := pm.NewProcess(ProcessNameDigestAPI, []string{ProcessNameDigestDatabase}, ProcessDigestAPI); err != nil {
panic(err)
} else {
ProcessorDigestAPI = i
}
if i, err := pm.NewProcess(
ProcessNameStartDigestAPI,
[]string{ProcessNameDigestDatabase, ProcessNameDigestAPI},
ProcessStartDigestAPI,
); err != nil {
panic(err)
} else {
ProcessorStartDigestAPI = i
}
}
func ProcessStartDigestAPI(ctx context.Context) (context.Context, error) {
var nt *digest.HTTP2Server
if err := LoadDigestNetworkContextValue(ctx, &nt); err != nil {
if errors.Is(err, util.ContextValueNotFoundError) {
return ctx, nil
}
return ctx, err
}
return ctx, nt.Start()
}
func ProcessDigestAPI(ctx context.Context) (context.Context, error) {
var design currencycmds.DigestDesign
if err := LoadDigestDesignContextValue(ctx, &design); err != nil {
if errors.Is(err, util.ContextValueNotFoundError) {
return ctx, nil
}
return ctx, err
}
var log *logging.Logging
if err := config.LoadLogContextValue(ctx, &log); err != nil {
return ctx, err
}
var networkLog *logging.Logging
if err := config.LoadNetworkLogContextValue(ctx, &networkLog); err != nil {
return ctx, err
}
if design.Network() == nil {
log.Log().Debug().Msg("digest api disabled; empty network")
return ctx, nil
}
var st *digest.Database
if err := LoadDigestDatabaseContextValue(ctx, &st); err != nil {
log.Log().Debug().Err(err).Msg("digest api disabled; empty database")
return ctx, nil
} else if st == nil {
log.Log().Debug().Msg("digest api disabled; empty database")
return ctx, nil
}
log.Log().Info().
Str("bind", design.Network().Bind().String()).
Str("publish", design.Network().ConnInfo().String()).
Msg("trying to start http2 server for digest API")
var nt *digest.HTTP2Server
var certs []tls.Certificate
if design.Network().Bind().Scheme == "https" {
certs = design.Network().Certs()
}
if sv, err := digest.NewHTTP2Server(
design.Network().Bind().Host,
design.Network().ConnInfo().URL().Host,
certs,
); err != nil {
return ctx, err
} else if err := sv.Initialize(); err != nil {
return ctx, err
} else {
_ = sv.SetLogging(networkLog)
nt = sv
}
return context.WithValue(ctx, ContextValueDigestNetwork, nt), nil
}