diff options
author | Jordan Augé <jordan.auge+fdio@cisco.com> | 2019-11-27 09:05:39 +0100 |
---|---|---|
committer | Jordan Augé <jordan.auge+fdio@cisco.com> | 2019-12-05 00:32:28 +0100 |
commit | 94350c13fe983a7cfb99dafecb0d029ed58361bf (patch) | |
tree | ed82fbed47a3ec2b9855e93402b3f75f3f403b57 /hicn-light/src/hicn/config | |
parent | dafa145fb5a4a10c1e600ee72fe639ac4f7e718d (diff) |
[HICN-420] MAP-Me code refactoring & face manager changes in support of mobility
Change-Id: Ifde50b4c161d1bda1326f18b705f575e539aea71
Signed-off-by: Jordan Augé <jordan.auge+fdio@cisco.com>
Diffstat (limited to 'hicn-light/src/hicn/config')
-rw-r--r-- | hicn-light/src/hicn/config/configuration.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/hicn-light/src/hicn/config/configuration.c b/hicn-light/src/hicn/config/configuration.c index 0466189cb..52dbf7a47 100644 --- a/hicn-light/src/hicn/config/configuration.c +++ b/hicn-light/src/hicn/config/configuration.c @@ -1197,6 +1197,26 @@ struct iovec *configuration_ConnectionSetPriority(Configuration *config, return utils_CreateAck(header, control, sizeof(connection_set_priority_command)); } +struct iovec *configuration_ConnectionSetTags(Configuration *config, + struct iovec *request) { + header_control_message *header = request[0].iov_base; + connection_set_tags_command *control = request[1].iov_base; + + Connection * conn = getConnectionBySymbolicOrId(config, control->symbolicOrConnid); + if (!conn) + return utils_CreateNack(header, control, sizeof(connection_set_tags_command)); + + connection_SetTags(conn, control->tags); + +#ifdef WITH_MAPME + /* Hook: connection event */ + forwarder_onConnectionEvent(config->forwarder, conn, + CONNECTION_EVENT_TAGS_CHANGED); +#endif /* WITH_MAPME */ + + return utils_CreateAck(header, control, sizeof(connection_set_tags_command)); +} + struct iovec *configuration_ProcessPolicyAdd(Configuration *config, struct iovec *request) { header_control_message *header = request[0].iov_base; @@ -1402,6 +1422,10 @@ struct iovec *configuration_DispatchCommand(Configuration *config, case CONNECTION_SET_PRIORITY: response = configuration_ConnectionSetPriority(config, control); break; + + case CONNECTION_SET_TAGS: + response = configuration_ConnectionSetTags(config, control); + break; #endif /* WITH_POLICY */ default: |