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
|
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
#include "configsetsource.h"
#include <vespa/config/print/asciiconfigwriter.h>
#include <vespa/config/common/iconfigholder.h>
#include <vespa/config/common/exceptions.h>
#include <cinttypes>
#include <vespa/log/log.h>
LOG_SETUP(".config.set.configsetsource");
namespace config {
ConfigSetSource::ConfigSetSource(std::shared_ptr<IConfigHolder> holder, const ConfigKey & key, BuilderMapSP builderMap)
: _holder(std::move(holder)),
_key(key),
_generation(1),
_builderMap(std::move(builderMap))
{
if (!validRequest(key))
throw ConfigRuntimeException("Invalid subscribe for key " + key.toString() + ", not builder found");
}
ConfigSetSource::~ConfigSetSource() = default;
void
ConfigSetSource::getConfig()
{
BuilderMap::const_iterator it(_builderMap->find(_key));
ConfigInstance * instance = it->second;
vespalib::asciistream ss;
AsciiConfigWriter writer(ss);
writer.write(*instance);
StringVector lines(getlines(ss));
vespalib::string currentXxhash64(calculateContentXxhash64(lines));
if (isGenerationNewer(_generation, _lastState.generation) && currentXxhash64.compare(_lastState.xxhash64) != 0) {
LOG(debug, "New generation, updating");
_holder->handle(std::make_unique<ConfigUpdate>(ConfigValue(std::move(lines), currentXxhash64), true, _generation));
_lastState.xxhash64 = currentXxhash64;
_lastState.generation = _generation;
} else {
LOG(debug, "Sending timestamp update");
_holder->handle(std::make_unique<ConfigUpdate>(ConfigValue(std::move(lines), currentXxhash64), false, _generation));
_lastState.generation = _generation;
}
}
void
ConfigSetSource::reload(int64_t generation)
{
LOG(debug, "Running update with generation(%" PRId64 ")", generation);
_generation = generation;
}
void
ConfigSetSource::close()
{
}
bool
ConfigSetSource::validRequest(const ConfigKey & key)
{
if (_builderMap->find(key) == _builderMap->end())
return false;
BuilderMap::const_iterator it(_builderMap->find(key));
ConfigInstance * instance = it->second;
return (key.getDefName().compare(instance->defName()) == 0 &&
key.getDefNamespace().compare(instance->defNamespace()) == 0);
}
} // namespace config
|