Apache Log4cxx  Version 1.7.0
Loading...
Searching...
No Matches
telnetappender.h
Go to the documentation of this file.
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements. See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#ifndef _LOG4CXX_NET_TELNET_APPENDER_H
19#define _LOG4CXX_NET_TELNET_APPENDER_H
20
23
24namespace LOG4CXX_NS
25{
26namespace helpers
27{
28class ByteBuffer;
29}
30namespace net
31{
32
52class LOG4CXX_EXPORT TelnetAppender : public AppenderSkeleton
53{
54 private:
55 static const int DEFAULT_PORT;
56 static const int MAX_CONNECTIONS;
57
58 public:
64
67
71 bool requiresLayout() const override;
72
84 void setEncoding(const LogString& value);
85
86
94
95
110 void setOption(const LogString& option, const LogString& value) override;
111
115 int getPort() const;
116
120 void setPort(int newValue);
121
126
131 void setHostname(const LogString& newValue);
132
138 int getMaxConnections() const;
139
145 void setMaxConnections(int newValue);
146
154 void setReuseAddress(bool newValue);
155
163 void setNonBlocking(bool newValue);
164
166 void close() override;
167
168 protected:
171 void append(const spi::LoggingEventPtr& event, helpers::Pool& p) override;
172
173 private:
174 // prevent copy and assignment statements
176 TelnetAppender& operator=(const TelnetAppender&);
177
178 void write(helpers::ByteBuffer&);
179 void writeStatus(const helpers::SocketPtr& socket, const LogString& msg, helpers::Pool& p);
180 void acceptConnections();
181
182 struct TelnetAppenderPriv;
183}; // class TelnetAppender
184
186} // namespace net
187} // namespace log4cxx
188
189#endif // _LOG4CXX_NET_TELNET_APPENDER_H
190
AppenderSkeleton(LOG4CXX_PRIVATE_PTR(AppenderSkeletonPrivate) priv)
The TelnetAppender writes log messages to clients that connect to the TCP port.
Definition telnetappender.h:53
void close() override
Shutdown this appender.
LogString getHostname() const
The Hostname on which to accept connections.
void setReuseAddress(bool newValue)
Use newValue for the SO_REUSEADDR option of the socket accepting connections.
void append(const spi::LoggingEventPtr &event, helpers::Pool &1) override
Send event to each connected client.
void activateOptions(helpers::Pool &) override
void setOption(const LogString &option, const LogString &value) override
Set option to value.
LogString getEncoding() const
The current encoding value.
int getPort() const
The TCP Port number on which to accept connections.
void setEncoding(const LogString &value)
Set the encoding to value.
void setHostname(const LogString &newValue)
Use newValue as the Hostname on which to accept connections.
void setMaxConnections(int newValue)
Set the number of allowed concurrent connections to newValue.
bool requiresLayout() const override
If no layout is provided, sends only the log message to attached client(s).
void setPort(int newValue)
Use newValue as the TCP port number on which to accept connections.
int getMaxConnections() const
The number of allowed concurrent connections.
void setNonBlocking(bool newValue)
Use newValue for the behaviour when the TCP send buffer (on an accepted socket connection) is full.
Definition propertysetter.h:27
LOG4CXX_PTR_DEF(SMTPAppender)
Definition appender.h:30
std::basic_string< logchar > LogString
Definition logstring.h:60
#define LOG4CXX_CAST_ENTRY(Interface)
Definition object.h:154
#define END_LOG4CXX_CAST_MAP()
Definition object.h:148
#define DECLARE_LOG4CXX_OBJECT(object)
Definition object.h:41
#define LOG4CXX_CAST_ENTRY_CHAIN(Interface)
Definition object.h:160
#define BEGIN_LOG4CXX_CAST_MAP()
Definition object.h:142
#define LOG4CXX_ACTIVATE_OPTIONS_FORMAL_PARAMETERS
Activate the options that were previously set with calls to option setters.
Definition optionhandler.h:53