c2b9fec50b
Require that users and groups found in /vendor/etc/{passwd,group} start with vendor_. This is needed to compliance with Treble as without this prefix, it is possible for a new system image to create a user/group name that a vendor has already used, causing a collision. Bug: 79528966 Test: new unit test Change-Id: I07500641e165f41526a8101592d83fa174e7a711
50 lines
1.9 KiB
C
50 lines
1.9 KiB
C
#pragma once
|
|
|
|
/*
|
|
* Copyright (C) 2017 The Android Open Source Project
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* * Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in
|
|
* the documentation and/or other materials provided with the
|
|
* distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*/
|
|
|
|
#include <grp.h>
|
|
#include <pwd.h>
|
|
|
|
static constexpr size_t kGrpPwdBufferSize = 32;
|
|
|
|
struct group_state_t {
|
|
group group_;
|
|
char* group_members_[2];
|
|
char group_name_buffer_[kGrpPwdBufferSize];
|
|
// Must be last so init_group_state can run a simple memset for the above
|
|
ssize_t getgrent_idx;
|
|
};
|
|
|
|
struct passwd_state_t {
|
|
passwd passwd_;
|
|
char name_buffer_[kGrpPwdBufferSize];
|
|
char dir_buffer_[kGrpPwdBufferSize];
|
|
char sh_buffer_[kGrpPwdBufferSize];
|
|
ssize_t getpwent_idx;
|
|
};
|