summaryrefslogtreecommitdiff
path: root/cpp/lib/common/framing/ChannelAdapter.cpp
blob: 653e47048e9f5a92abb833935d2c888a937884a1 (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
/*
 *
 * Copyright (c) 2006 The Apache Software Foundation
 *
 * 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.
 *
 */

#include "ChannelAdapter.h"
#include "AMQFrame.h"

namespace qpid {
namespace framing {

void ChannelAdapter::init(
    ChannelId i, OutputHandler& o, const ProtocolVersion& v)
{
    assertChannelNotOpen();
    id = i;
    out = &o;
    version = v;
    context = MethodContext(0, id, this);
}

void ChannelAdapter::send(AMQFrame* frame) {
    assertChannelOpen();
    AMQBody::shared_ptr body = frame->getBody();
    switch (body->type()) {
      case REQUEST_BODY: {
          AMQRequestBody::shared_ptr request =
              boost::shared_polymorphic_downcast<AMQRequestBody>(body);
          requester.sending(request->getData());
          break;
      }
      case RESPONSE_BODY: {
          AMQResponseBody::shared_ptr response =
              boost::shared_polymorphic_downcast<AMQResponseBody>(body);
          responder.sending(response->getData());
          break;
      }
    }
    out->send(frame);
}

void ChannelAdapter::send(AMQBody::shared_ptr body) {
    send(new AMQFrame(getVersion(), getId(), body));
}

void ChannelAdapter::handleRequest(AMQRequestBody::shared_ptr request) {
    assertMethodOk(*request);
    responder.received(request->getData());
    context =MethodContext(request.get(), id, this, request->getRequestId());
    handleMethodInContext(request, context);
}

void ChannelAdapter::handleResponse(AMQResponseBody::shared_ptr response) {
    assertMethodOk(*response);
    // TODO aconway 2007-01-30: Consider a response handled on receipt.
    // Review - any cases where this is not the case?
    requester.processed(response->getData());
    handleMethod(response);
}

void ChannelAdapter::handleMethod(AMQMethodBody::shared_ptr method) {
    assertMethodOk(*method);
    context = MethodContext(method.get(), id, this);
    handleMethodInContext(method, context);
}

void ChannelAdapter::assertMethodOk(AMQMethodBody& /*method*/) const {
    // No connection methods allowed on a non-zero channel
    // Subclass ChannelZero overrides for 0 channels.
    // FIXME aconway 2007-01-25: with ctors
//     assertChannelOpen();
//     if (method.amqpClassId() == ConnectionOpenBody::CLASS_ID)
//         throw ConnectionException(
//             504, "Connection method on non-0 channel.");
}

void ChannelAdapter::assertChannelOpen() const {
    // FIXME aconway 2007-01-25: with ctors
//     if (!isOpen())
//         throw ConnectionException(504, "Channel is not open");
}

void ChannelAdapter::assertChannelNotOpen() const {
    // FIXME aconway 2007-01-25: with ctors
//     if (isOpen())
//         throw ConnectionException(504, "Channel is already open");
}

}} // namespace qpid::framing