/**
  Juju Logger version 1.
  This facade is available on:
    Controller-machine-agent
    Machine-agent
    Unit-agent
    Models

  NOTE: This file was generated using the Juju schema
  from Juju 3.3 at the git SHA 65fa4c1ee5.
  Do not manually edit this file.
*/
import { ConnectionInfo, Transport } from "../../client.js";
import { Facade } from "../../types.js";
export interface Entities {
    entities: Entity[];
}
export interface Entity {
    tag: string;
}
export interface Error {
    code: string;
    info?: AdditionalProperties;
    message: string;
}
export interface NotifyWatchResult {
    NotifyWatcherId: string;
    error?: Error;
}
export interface NotifyWatchResults {
    results: NotifyWatchResult[];
}
export interface StringResult {
    error?: Error;
    result: string;
}
export interface StringResults {
    results: StringResult[];
}
export interface AdditionalProperties {
    [key: string]: any;
}
/**
  LoggerAPI implements the Logger interface and is the concrete
  implementation of the api end point.
*/
declare class LoggerV1 implements Facade {
    static NAME: string;
    static VERSION: number;
    NAME: string;
    VERSION: number;
    _transport: Transport;
    _info: ConnectionInfo;
    constructor(transport: Transport, info: ConnectionInfo);
    /**
      LoggingConfig reports the logging configuration for the agents specified.
    */
    loggingConfig(params: Entities): Promise<StringResults>;
    /**
      WatchLoggingConfig starts a watcher to track changes to the logging config
      for the agents specified..  Unfortunately the current infrastructure makes
      watching parts of the config non-trivial, so currently any change to the
      config will cause the watcher to notify the client.
    */
    watchLoggingConfig(params: Entities): Promise<NotifyWatchResults>;
}
export default LoggerV1;
