summaryrefslogtreecommitdiff
path: root/cpp/src/qmf/engine/EventImpl.cpp
blob: 3509220b0cea2852da23fe83dd80c89b5f0a6170 (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
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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 <qmf/engine/EventImpl.h>
#include <qmf/engine/ValueImpl.h>

#include <sstream>

using namespace std;
using namespace qmf::engine;
using qpid::framing::Buffer;

EventImpl::EventImpl(const SchemaEventClass* type) : eventClass(type)
{
    int argCount = eventClass->getArgumentCount();
    int idx;

    for (idx = 0; idx < argCount; idx++) {
        const SchemaArgument* arg = eventClass->getArgument(idx);
        arguments[arg->getName()] = ValuePtr(new Value(arg->getType()));
    }
}


EventImpl::EventImpl(const SchemaEventClass* type, Buffer&) :
    eventClass(type)
{
}


Event* EventImpl::factory(const SchemaEventClass* type, Buffer& buffer)
{
    EventImpl* impl(new EventImpl(type, buffer));
    return new Event(impl);
}


Value* EventImpl::getValue(const char* key) const
{
    map<string, ValuePtr>::const_iterator iter;

    iter = arguments.find(key);
    if (iter != arguments.end())
        return iter->second.get();

    return 0;
}


void EventImpl::encodeSchemaKey(Buffer& buffer) const
{
    buffer.putShortString(eventClass->getClassKey()->getPackageName());
    buffer.putShortString(eventClass->getClassKey()->getClassName());
    buffer.putBin128(const_cast<uint8_t*>(eventClass->getClassKey()->getHash()));
}


void EventImpl::encode(Buffer& buffer) const
{
    buffer.putOctet((uint8_t) eventClass->getSeverity());

    int argCount = eventClass->getArgumentCount();
    for (int idx = 0; idx < argCount; idx++) {
        const SchemaArgument* arg = eventClass->getArgument(idx);
        ValuePtr value = arguments[arg->getName()];
        value->impl->encode(buffer);
    }
}


string EventImpl::getRoutingKey(uint32_t brokerBank, uint32_t agentBank) const
{
    stringstream key;

    key << "console.event." << brokerBank << "." << agentBank << "." <<
        eventClass->getClassKey()->getPackageName() << "." <<
        eventClass->getClassKey()->getClassName();
    return key.str();
}


//==================================================================
// Wrappers
//==================================================================

Event::Event(const SchemaEventClass* type) : impl(new EventImpl(type)) {}
Event::Event(EventImpl* i) : impl(i) {}
Event::Event(const Event& from) : impl(new EventImpl(*(from.impl))) {}
Event::~Event() { delete impl; }
const SchemaEventClass* Event::getClass() const { return impl->getClass(); }
Value* Event::getValue(const char* key) const { return impl->getValue(key); }