blob: 3f8b63e088194c6e392f1a402aaca5401210d7b2 [file] [log] [blame]
"""
Copyright 2020 The Magma Authors.
This source code is licensed under the BSD-style license found in the
LICENSE file in the root directory of this source tree.
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.
"""
import logging
import grpc
from google.protobuf.json_format import MessageToDict
from common.service_registry import ServiceRegistry
from orc8r.protos.eventd_pb2 import Event
from orc8r.protos.eventd_pb2_grpc import EventServiceStub
EVENTD_SERVICE_NAME = "eventd"
DEFAULT_GRPC_TIMEOUT = 10
def log_event(event: Event) -> None:
"""
Make RPC call to 'LogEvent' method of local eventD service
"""
try:
chan = ServiceRegistry.get_rpc_channel(
EVENTD_SERVICE_NAME, ServiceRegistry.LOCAL,
)
except ValueError:
logging.error("Cant get RPC channel to %s", EVENTD_SERVICE_NAME)
return
client = EventServiceStub(chan)
try:
# Location will be filled in by directory service
client.LogEvent(event, DEFAULT_GRPC_TIMEOUT)
except grpc.RpcError as err:
if err.code() == grpc.StatusCode.UNAVAILABLE:
logging.debug(
"LogEvent will not occur unless eventd configuration "
"is set up.",
)
else:
logging.error(
"LogEvent error for event: %s, [%s] %s",
MessageToDict(event),
err.code(),
err.details(),
)