/
cron.scala
64 lines (53 loc) · 2.35 KB
/
cron.scala
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
//: ----------------------------------------------------------------------------
//: Copyright (C) 2017 Verizon. All Rights Reserved.
//:
//: 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 nelson
package routing
import cats.effect.{Effect, IO}
import nelson.CatsHelpers._
import fs2.{Scheduler, Stream}
import scalaz._
import Scalaz._
import journal.Logger
import helm.ConsulOp
object cron {
private[cron] val log = Logger[cron.type]
def refresh(cfg: NelsonConfig): IO[List[(Datacenter,ConsulOp.ConsulOpF[Unit])]] = {
cfg.datacenters.traverseM { dc =>
log.info(s"cron: refreshing ${dc.name}")
for {
rts <- nelson.storage.run(cfg.storage, RoutingTable.generateRoutingTables(dc.name))
dts = Discovery.discoveryTables(rts).toList
dtout = dts.map {
case ((sn,ns),dts) =>
log.debug(s"cron: refressing lighthouse table for ${sn}")
dc -> Discovery.writeDiscoveryInfoToConsul(ns, sn, dc.domain.name, dts)
}
lbout = rts.flatMap { case (_ , gr) =>
loadbalancers.loadbalancerV1Configs(gr).map { case ((lb, ins)) =>
log.debug(s"cron: refreshing proxy configuration for ${lb}")
dc -> loadbalancers.writeLoadbalancerV1ConfigToConsul(lb, ins)
}
}
} yield dtout ++ lbout
}
}
def consulRefresh(cfg: NelsonConfig): Stream[IO,(Datacenter,ConsulOp.ConsulOpF[Unit])] =
Stream.repeatEval(IO(cfg.discoveryDelay)).
flatMap(d => Scheduler.fromScheduledExecutorService(cfg.pools.schedulingPool).awakeEvery(d)(Effect[IO], cfg.pools.defaultExecutor).head).
flatMap(_ => Stream.eval(refresh(cfg)).attempt.observeW(cfg.auditor.errorSink)(Effect[IO], cfg.pools.defaultExecutor).stripW).
flatMap(xs => Stream.emits(xs))
}