X-Git-Url: https://the.earth.li/gitweb/?a=blobdiff_plain;f=keyd.h;h=1ea601c82777af9de57ecc039578f0e8b4e1b5b3;hb=adc800dbc424a1e246dd4a82a0c2e88eeda25531;hp=ce19d8dd13f0c78fda9911fd8e9456ea627da9a6;hpb=7a0ffbb5910bd782ef569b63ce665659e3564e72;p=onak.git diff --git a/keyd.h b/keyd.h index ce19d8d..1ea601c 100644 --- a/keyd.h +++ b/keyd.h @@ -1,9 +1,20 @@ -/* - * keyd.h - Public API for keyd. +/** + * @file keyd.h + * @brief Public API for keyd. * - * Jonathan McDowell + * Copyright 2004,2011 Jonathan McDowell * - * Copyright 2004 Project Purple + * This program is free software: you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the Free + * Software Foundation; version 2 of the License. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for + * more details. + * + * You should have received a copy of the GNU General Public License along with + * this program. If not, see . */ #ifndef __KEYD_H__ @@ -11,33 +22,54 @@ #include +/** + * @brief The name of the keyd Unix domain socket + */ #define KEYD_SOCKET "keyd.sock" +/** + * @brief keyd commands + */ enum keyd_ops { KEYD_CMD_UNKNOWN = 0, KEYD_CMD_VERSION = 1, - KEYD_CMD_GET, + KEYD_CMD_GET_ID, KEYD_CMD_STORE, KEYD_CMD_DELETE, - KEYD_CMD_GETTEXT, + KEYD_CMD_GET_TEXT, KEYD_CMD_GETFULLKEYID, KEYD_CMD_KEYITER, KEYD_CMD_CLOSE, KEYD_CMD_QUIT, KEYD_CMD_STATS, + KEYD_CMD_GET_SKSHASH, + KEYD_CMD_GET_FP, + KEYD_CMD_UPDATE, KEYD_CMD_LAST /* Placeholder */ }; +/** + * @brief Reply codes for keyd commands + */ enum keyd_reply { KEYD_REPLY_OK = 0, KEYD_REPLY_UNKNOWN_CMD = 1 }; -static uint32_t keyd_version = 2; +/** + * @brief Version of the keyd protocol currently supported + */ +static const uint32_t keyd_version = 5; +/** + * @brief Response structure for the @a KEYD_CMD_STATS response + */ struct keyd_stats { + /** Unix time of when the keyd daemon was started */ time_t started; + /** Number of connects we've seen to keyd */ uint32_t connects; + /** Count of the number of times each command has been used */ uint32_t command_stats[KEYD_CMD_LAST]; };