X-Git-Url: https://the.earth.li/gitweb/?p=onak.git;a=blobdiff_plain;f=keyd.h;h=1ea601c82777af9de57ecc039578f0e8b4e1b5b3;hp=4313a4f005dd4a96c33e887b425ef5d15d6981b9;hb=adc800dbc424a1e246dd4a82a0c2e88eeda25531;hpb=7ca3c239d76ae7112c166f29c35e11620ba93d9f diff --git a/keyd.h b/keyd.h index 4313a4f..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,34 +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_GETSKSHASH, + 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 = 3; +/** + * @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]; };