// Copyright 2018 The Fuchsia Authors. All rights reserved.
|
// Use of this source code is governed by a BSD-style license that can be
|
// found in the LICENSE file.
|
|
library fuchsia.logger;
|
|
using zx;
|
|
enum LogLevelFilter : int8 {
|
NONE = -1;
|
INFO = 0;
|
WARN = 1;
|
ERROR = 2;
|
FATAL = 3;
|
};
|
|
// Max tags that can be passed to filter by listener.
|
const uint8 MAX_TAGS = 5;
|
|
// Max tag length that can be passed to filter by listener.
|
const uint8 MAX_TAG_LEN_BYTES = 63;
|
|
struct LogFilterOptions {
|
bool filter_by_pid;
|
uint64 pid;
|
|
bool filter_by_tid;
|
uint64 tid;
|
|
// If more than zero, logs would be filtered based on verbosity and
|
// |min_severity| would be ignored.
|
uint8 verbosity;
|
|
LogLevelFilter min_severity;
|
|
// If non-empty, return all messages which contain at least one specified
|
// tag. If empty, messages will not be filtered by tag.
|
// Passed tags should not be more than |MAX_TAG_LEN_BYTES| bytes in length
|
// and max tags can be |MAX_TAGS|.
|
// Listener would be discarded if the limit is not followed.
|
vector<string>:MAX_TAGS tags;
|
};
|
|
// Max tags that will be attached to a LogMessage.
|
const uint8 MAX_TAGS_PER_LOG_MESSAGE = 5;
|
|
struct LogMessage {
|
uint64 pid;
|
uint64 tid;
|
// Nanoseconds since the system was powered on, aka ZX_CLOCK_MONOTONIC.
|
// https://fuchsia.googlesource.com/zircon/+/master/docs/syscalls/clock_get.md#supported-clock-ids
|
zx.time time;
|
int32 severity;
|
|
// See //zircon/system/ulib/syslog/include/syslog/wire_format.h. As messages
|
// can be served out of order, this should only be logged if more than last
|
// count.
|
uint32 dropped_logs;
|
vector<string>:MAX_TAGS_PER_LOG_MESSAGE tags;
|
string msg;
|
};
|
|
// Interface for LogListener to register to listen to logs.
|
[Discoverable]
|
interface Log {
|
// Listens to new log entries by calling Log() on |log_listener|.
|
// A null |options| indicates no filtering is requested.
|
1: Listen(LogListener log_listener, LogFilterOptions? options);
|
|
// Dumps all cached logs by calling LogMany() followed by Done() on
|
// |log_listener|.
|
// A null |options| indicates no filtering is requested.
|
2: DumpLogs(LogListener log_listener, LogFilterOptions? options);
|
};
|
|
// Interface to get and listen to socket from syslogger
|
[Discoverable]
|
interface LogSink {
|
// Client connects to send logs over socket
|
1: Connect(handle<socket> socket);
|
};
|
|
const uint64 MAX_LOG_MANY_SIZE_BYTES = 16384;
|
|
interface LogListener {
|
// Called for single messages.
|
1: Log(LogMessage log);
|
|
// Called when |Log| service is serving cached logs.
|
// Max logs size per call is |MAX_LOG_MANY_SIZE_BYTES| bytes.
|
2: LogMany(vector<LogMessage> log);
|
|
// Called in the case |DumpLogs()| function of |Log| service was called and
|
// all cached logs have been dispatched to this listener.
|
3: Done();
|
};
|