summaryrefslogtreecommitdiff
path: root/implementation/endpoints/src/local_client_endpoint_impl.cpp
blob: 62dba827c3b20603c70dd81bda60de316cdec7f9 (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
// Copyright (C) 2014-2016 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 <iomanip>
#include <sstream>

#include <boost/asio/write.hpp>

#include <vsomeip/defines.hpp>

#include "../include/endpoint_host.hpp"
#include "../include/local_client_endpoint_impl.hpp"
#include "../../logging/include/logger.hpp"

namespace vsomeip {

local_client_endpoint_impl::local_client_endpoint_impl(
        std::shared_ptr< endpoint_host > _host,
        endpoint_type _remote,
        boost::asio::io_service &_io,
        std::uint32_t _max_message_size)
    : local_client_endpoint_base_impl(_host, _remote, _remote, _io, _max_message_size) {
									  // Using _remote for the local(!) endpoint is ok,
									  // because we have no bind for local endpoints!
    is_supporting_magic_cookies_ = false;
}

local_client_endpoint_impl::~local_client_endpoint_impl() {

}

bool local_client_endpoint_impl::is_local() const {
    return true;
}

void local_client_endpoint_impl::start() {
    if (socket_.is_open()) {
        sending_blocked_ = false;
        boost::system::error_code its_error;
        socket_.cancel(its_error);
        socket_.close(its_error);
        restart();
    } else {
        connect();
    }
}

void local_client_endpoint_impl::connect() {
    boost::system::error_code its_error;
    socket_.open(remote_.protocol(), its_error);

    if (!its_error || its_error == boost::asio::error::already_open) {
        socket_.set_option(boost::asio::socket_base::reuse_address(true));
        boost::system::error_code error;
        error = socket_.connect(remote_, error);
        connect_cbk(error);
    } else {
        VSOMEIP_WARNING << "local_client_endpoint::connect: Error opening socket: "
                << its_error.message();
    }
}

void local_client_endpoint_impl::receive() {
}

void local_client_endpoint_impl::send_queued() {
    static byte_t its_start_tag[] = { 0x67, 0x37, 0x6D, 0x07 };
    static byte_t its_end_tag[] = { 0x07, 0x6D, 0x37, 0x67 };
    std::vector<boost::asio::const_buffer> bufs;

    message_buffer_ptr_t its_buffer;
    if(queue_.size()) {
        its_buffer = queue_.front();
    } else {
        return;
    }

#if 0
std::stringstream msg;
msg << "lce<" << this << ">::sq: ";
for (std::size_t i = 0; i < its_buffer->size(); i++)
    msg << std::setw(2) << std::setfill('0') << std::hex
        << (int)(*its_buffer)[i] << " ";
VSOMEIP_DEBUG << msg.str();
#endif

    bufs.push_back(boost::asio::buffer(its_start_tag));
    bufs.push_back(boost::asio::buffer(*its_buffer));
    bufs.push_back(boost::asio::buffer(its_end_tag));

    boost::asio::async_write(
        socket_,
        bufs,
        std::bind(
            &client_endpoint_impl::send_cbk,
            std::dynamic_pointer_cast<
                local_client_endpoint_impl
            >(shared_from_this()),
            std::placeholders::_1,
            std::placeholders::_2
        )
    );
}

void local_client_endpoint_impl::send_magic_cookie() {
}

} // namespace vsomeip