summaryrefslogtreecommitdiff
path: root/implementation/protocol/src/update_security_policy_command.cpp
blob: 8ff79e2c8d96020d5932ea904426f5c34c7ab7f9 (plain)
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
// Copyright (C) 2021 Bayerische Motoren Werke Aktiengesellschaft (BMW AG)
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.

#include <limits>

#include "../include/update_security_policy_command.hpp"
#include "../../security/include/policy.hpp"

namespace vsomeip_v3 {
namespace protocol {

update_security_policy_command::update_security_policy_command(
        bool _is_internal)
    : command(_is_internal ?
            id_e::UPDATE_SECURITY_POLICY_INT_ID :
            id_e::UPDATE_SECURITY_POLICY_ID) {
}

void
update_security_policy_command::serialize(std::vector<byte_t> &_buffer,
        error_e &_error) const {

    std::vector<byte_t> its_policy_data;
    if (policy_) {
         if (policy_->serialize(its_policy_data)) {
             _error = error_e::ERROR_UNKNOWN;
             return;
         }
    }

    size_t its_size(COMMAND_HEADER_SIZE + sizeof(update_id_)
            + its_policy_data.size());

    if (its_size > std::numeric_limits<command_size_t>::max()) {

        _error = error_e::ERROR_MAX_COMMAND_SIZE_EXCEEDED;
        return;
    }

    // resize buffer
    _buffer.resize(its_size);

    // set size
    size_ = static_cast<command_size_t>(its_size - COMMAND_HEADER_SIZE);

    // serialize header
    command::serialize(_buffer, _error);
    if (_error != error_e::ERROR_OK)
        return;

    // serialize payload
    size_t its_offset(COMMAND_HEADER_SIZE);
    std::memcpy(&_buffer[its_offset], &update_id_, sizeof(update_id_));
    its_offset += sizeof(update_id_);
    std::memcpy(&_buffer[its_offset],
            &its_policy_data[0], its_policy_data.size());
}

void
update_security_policy_command::deserialize(const std::vector<byte_t> &_buffer,
        error_e &_error) {

    if (COMMAND_HEADER_SIZE + sizeof(update_id_) > _buffer.size()) {

        _error = error_e::ERROR_NOT_ENOUGH_BYTES;
        return;
    }

    // deserialize header
    command::deserialize(_buffer, _error);
    if (_error != error_e::ERROR_OK)
        return;

    // deserialize payload
    std::memcpy(&update_id_, &_buffer[COMMAND_POSITION_PAYLOAD],
            sizeof(update_id_));
    policy_ = std::make_shared<policy>();
    const byte_t *its_policy_data
        = &_buffer[COMMAND_HEADER_SIZE + sizeof(update_id_)];
    uint32_t its_policy_size
        = uint32_t(_buffer.size() - COMMAND_HEADER_SIZE - sizeof(update_id_));

    if (its_policy_size == 0
            || !policy_->deserialize(its_policy_data, its_policy_size)) {

        _error = error_e::ERROR_UNKNOWN;
        policy_.reset();
        return;
    }
}

uint32_t
update_security_policy_command::get_update_id() const {

    return (update_id_);
}

void
update_security_policy_command::set_update_id(uint32_t _update_id) {

    update_id_ = _update_id;
}

std::shared_ptr<policy>
update_security_policy_command::get_policy() const {

    return (policy_);
}

void
update_security_policy_command::set_policy(
        const std::shared_ptr<policy> &_policy) {

    policy_ = _policy;
}

} // namespace protocol
} // namespace vsomeip