Skip to content
Snippets Groups Projects
Select Git revision
  • 491035ce1ceec310f98347654ea17cafa6ccb520
  • master default protected
  • android-7.1.2_r28_klist
  • oreo-mr1-iot-release
  • sdk-release
  • pie-cts-dev
  • pie-cts-release
  • pie-vts-release
  • nougat-iot-release
  • pie-gsi
  • pie-platform-release
  • pie-r2-release
  • pie-r2-s1-release
  • pie-release
  • pie-dev
  • oreo-m4-s4-release
  • o-mr1-iot-preview-8
  • oreo-m2-s2-release
  • oreo-m2-s1-release
  • oreo-m6-s2-release
  • oreo-m6-s3-release
  • android-o-mr1-iot-release-1.0.4
  • android-9.0.0_r8
  • android-9.0.0_r7
  • android-9.0.0_r6
  • android-9.0.0_r5
  • android-8.1.0_r46
  • android-8.1.0_r45
  • android-n-iot-release-smart-display-r2
  • android-vts-8.1_r5
  • android-cts-8.1_r8
  • android-cts-8.0_r12
  • android-cts-7.1_r20
  • android-cts-7.0_r24
  • android-cts-6.0_r31
  • android-o-mr1-iot-release-1.0.3
  • android-cts-9.0_r1
  • android-8.1.0_r43
  • android-8.1.0_r42
  • android-n-iot-release-smart-display
  • android-p-preview-5
41 results

libaudit.h

Blame
  • user avatar
    Nick Kralevich authored
    Impose a limit of 20 selinux denials per second. Denials beyond
    that point don't add any value, and have the potential to cause
    crashes or denial of service attacks.
    
    Do some other misc cleanup while I'm here.
    
    Bug: 18341932
    
    (cherry picked from commit c234a1b8)
    
    Change-Id: Ic5c96003db82e504baf301e87be5c8c539c73c2a
    83d85563
    History
    libaudit.h 2.34 KiB
    /*
     * Copyright 2012, Samsung Telecommunications of America
     * Copyright (C) 2014 The Android Open Source Project
     *
     * Licensed under the Apache License, Version 2.0 (the "License");
     * you may not use this file except in compliance with the License.
     * You may obtain a copy of the License at
     *
     *     http://www.apache.org/licenses/LICENSE-2.0
     *
     * Unless required by applicable law or agreed to in writing, software
     * distributed under the License is distributed on an "AS IS" BASIS,
     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     * See the License for the specific language governing permissions and
     * limitations under the License.
     *
     * Written by William Roberts <w.roberts@sta.samsung.com>
     */
    
    #ifndef _LIBAUDIT_H_
    #define _LIBAUDIT_H_
    
    #include <stdint.h>
    #include <sys/cdefs.h>
    #include <sys/socket.h>
    #include <sys/types.h>
    
    #include <linux/netlink.h>
    #include <linux/audit.h>
    
    __BEGIN_DECLS
    
    #define MAX_AUDIT_MESSAGE_LENGTH    8970
    
    typedef enum {
        GET_REPLY_BLOCKING=0,
        GET_REPLY_NONBLOCKING
    } reply_t;
    
    /* type == AUDIT_SIGNAL_INFO */
    struct audit_sig_info {
        uid_t uid;
        pid_t pid;
        char ctx[0];
    };
    
    struct audit_message {
        struct nlmsghdr nlh;
        char   data[MAX_AUDIT_MESSAGE_LENGTH];
    };
    
    /**
     * Opens a connection to the Audit netlink socket
     * @return
     *  A valid fd on success or < 0 on error with errno set.
     *  Returns the same errors as man 2 socket.
     */
    extern int  audit_open(void);
    
    /**
     * Closes the fd returned from audit_open()
     * @param fd
     *  The fd to close
     */
    extern void audit_close(int fd);
    
    /**
     *
     * @param fd
     *  The fd returned by a call to audit_open()
     * @param rep
     *  The response struct to store the response in.
     * @param block
     *  Whether or not to block on IO
     * @param peek
     *  Whether or not we are to remove the message from
     *  the queue when we do a read on the netlink socket.
     * @return
     *  This function returns 0 on success, else -errno.
     */
    extern int  audit_get_reply(int fd, struct audit_message *rep, reply_t block,
                   int peek);
    
    /**
     * Sets a pid to recieve audit netlink events from the kernel
     * @param fd
     *  The fd returned by a call to audit_open()
     * @param pid
     *  The pid whom to set as the reciever of audit messages
     * @return
     *  This function returns 0 on success, -errno on error.
     */
    extern int  audit_setup(int fd, uint32_t pid);
    
    __END_DECLS
    
    #endif