1 /* 2 * Copyright (C) 2008 The Android Open Source Project 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * * Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * * Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in 12 * the documentation and/or other materials provided with the 13 * distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 */ 28 29 #pragma once 30 31 /** 32 * @file utmp.h 33 * @brief No-op implementation of non-POSIX login records. See <utmpx.h> for the POSIX equivalents. 34 */ 35 36 #include <sys/cdefs.h> 37 #include <sys/types.h> 38 #include <time.h> 39 40 #define _PATH_UTMP "/var/run/utmp" 41 #define _PATH_WTMP "/var/log/wtmp" 42 #define _PATH_LASTLOG "/var/log/lastlog" 43 44 #ifdef __LP64__ 45 #define UT_NAMESIZE 32 46 #define UT_LINESIZE 32 47 #define UT_HOSTSIZE 256 48 #else 49 #define UT_NAMESIZE 8 50 #define UT_LINESIZE 8 51 #define UT_HOSTSIZE 16 52 #endif 53 54 #define EMPTY 0 55 #define RUN_LVL 1 56 #define BOOT_TIME 2 57 #define NEW_TIME 3 58 #define OLD_TIME 4 59 #define INIT_PROCESS 5 60 #define LOGIN_PROCESS 6 61 #define USER_PROCESS 7 62 #define DEAD_PROCESS 8 63 #define ACCOUNTING 9 64 65 struct lastlog { 66 time_t ll_time; 67 char ll_line[UT_LINESIZE]; 68 char ll_host[UT_HOSTSIZE]; 69 }; 70 71 struct exit_status { 72 short e_termination; 73 short e_exit; 74 }; 75 76 struct utmp { 77 short ut_type; 78 pid_t ut_pid; 79 char ut_line[UT_LINESIZE]; 80 char ut_id[4]; 81 char ut_user[UT_NAMESIZE]; 82 char ut_host[UT_HOSTSIZE]; 83 84 struct exit_status ut_exit; 85 86 long ut_session; 87 struct timeval ut_tv; 88 89 int32_t ut_addr_v6[4]; 90 char unused[20]; 91 }; 92 93 #define ut_name ut_user 94 #define ut_time ut_tv.tv_sec 95 #define ut_addr ut_addr_v6[0] 96 97 __BEGIN_DECLS 98 99 /** 100 * Returns -1 and sets errno to ENOTSUP. 101 */ 102 int utmpname(const char* _Nonnull __path); 103 104 /** 105 * Does nothing. 106 */ 107 void setutent(void); 108 109 /** 110 * Does nothing and returns null. 111 */ 112 struct utmp* _Nullable getutent(void); 113 114 /** 115 * Does nothing and returns null. 116 */ 117 struct utmp* _Nullable pututline(const struct utmp* _Nonnull __entry); 118 119 /** 120 * Does nothing. 121 */ 122 void endutent(void); 123 124 /** 125 * [login_tty(3)](https://www.man7.org/linux/man-pages/man3/login_tty.3.html) 126 * prepares for login on the given file descriptor. 127 * 128 * See also forkpty() which combines openpty(), fork(), and login_tty(). 129 * 130 * Returns 0 on success and returns -1 and sets `errno` on failure. 131 * 132 * Available since API level 23. 133 */ 134 int login_tty(int __fd) __INTRODUCED_IN(23); 135 136 __END_DECLS 137