Spec-Zone .ru
спецификации, руководства, описания, API
Spec-Zone .ru
спецификации, руководства, описания, API
Библиотека разработчика Mac Разработчик
Поиск

 

Эта страница руководства является частью версии 5.0 Инструментов XCode

Получить эти инструменты:

Если Вы выполняете версию Инструментов XCode кроме 5,0, просматриваете документацию локально:

Читать страницы руководства

Страницы руководства предназначаются как справочник для людей, уже понимающих технологию.

  • Чтобы изучить, как руководство организовано или узнать о синтаксисе команды, прочитайте страницу руководства для страниц справочника (5).

  • Для получения дополнительной информации об этой технологии, ищите другую документацию в Библиотеке Разработчика Apple.

  • Для получения общей информации о записи сценариев оболочки, считайте Shell, Пишущий сценарий Учебника для начинающих.




audit_submit(3)          BSD Library Functions Manual          audit_submit(3)

NAME
     audit_submit -- general purpose audit record submission

LIBRARY
     Basic Security Module Library (libbsm, -lbsm)

SYNOPSIS
     #include <bsm/libbsm.h>

     int
     audit_submit(short au_event, au_id_t auid, char status, int reterr, const char * restrict format, ...);

DESCRIPTION
     The audit_submit() function provides a generic programming interface for audit record submission.  This
     audit record will contain a header, subject token, an optional text token, return token, and a trailer.
     The header will contain the event class specified by au_event.  The subject token will be generated
     based on auid.  The return token is dependent on the status and reterr arguments; unlike the argument
     to au_to_return, reterr should be a local rather than BSM error number.  Optionally, a text token will
     be created as a part of this record.

     Text token output is under the control of a format string that specifies how subsequent arguments (or
     arguments accessed via the variable-length argument facilities of stdarg(3)) are converted for output.
     If format is NULL, then no text token is created in the audit record.

     It should be noted that audit_submit() assumes that setaudit(2), or setaudit_addr(2) has already been
     called.  As a direct result, the terminal ID for the subject will be retrieved from the kernel via
     getaudit(2), or getaudit_addr(2).

EXAMPLES
           #include <bsm/audit.h>
           #include <bsm/libbsm.h>
           #include <bsm/audit_uevents.h>

           #include <stdio.h>
           #include <stdarg.h>
           #include <errno.h>

           void
           audit_bad_su(char *from_login, char *to_login)
           {
                   struct auditinfo_addr aia;
                   struct auditinfo ai;
                   au_id_t aid;
                   int error;

                   error = getaudit_addr(&aia, sizeof(aia));
                   if (error < 0 && errno == ENOSYS) {
                           error = getaudit(&ai);
                           if (error < 0)
                                   err(1, "getaudit");
                           aid = ai.ai_auid;
                   } else if (error < 0)
                           err(1, "getaudit_addr");
                   else
                           aid = aia.ai_auid;
                   error = audit_submit(AUE_su, aid, EPERM, 1,
                       "bad su from %s to %s", from_login, to_login);
                   if (error != 0)
                           err(1, "audit_submit");
           }

     Will generate the following audit record:

           header,94,1,su(1),0,Mon Apr 17 23:23:59 2006, + 271 msec
           subject,root,root,wheel,root,wheel,652,652,0,0.0.0.0
           text,bad su from from csjp to root
           return,failure : Operation not permitted,1
           trailer,94

RETURN VALUES
     If successful, audit_submit will return zero.  Otherwise a -1 is returned and the global variable errno
     is set to indicate the error.

SEE ALSO
     auditon(2), getaudit(2), libbsm(3), stdarg(3)

HISTORY
     The audit_submit() function first appeared in OpenBSM version 1.0.  OpenBSM 1.0 was introduced in
     FreeBSD 7.0.

AUTHORS
     The audit_submit() function was written by Christian S.J. Peron <csjp@FreeBSD.org>.

BSD                            January 18, 2008                            BSD

Сообщение о проблемах

Способ сообщить о проблеме с этой страницей руководства зависит от типа проблемы:

Ошибки содержания
Ошибки отчета в содержании этой документации со ссылками на отзыв ниже.
Отчеты об ошибках
Сообщите об ошибках в функциональности описанного инструмента или API через Генератор отчетов Ошибки.
Форматирование проблем
Отчет, форматирующий ошибки в интерактивной версии этих страниц со ссылками на отзыв ниже.