/**
  Juju KeyManager version 1.
  This facade is available on:
    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 ErrorResult {
    error?: Error;
}
export interface ErrorResults {
    results: ErrorResult[];
}
export interface ListSSHKeys {
    entities: Entities;
    mode: boolean;
}
export interface ModifyUserSSHKeys {
    "ssh-keys": string[];
    user: string;
}
export interface StringsResult {
    error?: Error;
    result?: string[];
}
export interface StringsResults {
    results: StringsResult[];
}
export interface AdditionalProperties {
    [key: string]: any;
}
/**
  KeyManagerAPI provides api endpoints for manipulating ssh keys
*/
declare class KeyManagerV1 implements Facade {
    static NAME: string;
    static VERSION: number;
    NAME: string;
    VERSION: number;
    _transport: Transport;
    _info: ConnectionInfo;
    constructor(transport: Transport, info: ConnectionInfo);
    /**
      AddKeys adds new authorised ssh keys for the specified user.
    */
    addKeys(params: ModifyUserSSHKeys): Promise<ErrorResults>;
    /**
      DeleteKeys deletes the authorised ssh keys for the specified user.
    */
    deleteKeys(params: ModifyUserSSHKeys): Promise<ErrorResults>;
    /**
      ImportKeys imports new authorised ssh keys from the specified key ids for the specified user.
    */
    importKeys(params: ModifyUserSSHKeys): Promise<ErrorResults>;
    /**
      ListKeys returns the authorised ssh keys for the specified users.
    */
    listKeys(params: ListSSHKeys): Promise<StringsResults>;
}
export default KeyManagerV1;
