# # Author:: Adam Jacob () # Author:: Tyler Cloke () # Copyright:: Copyright 2008-2018, Chef Software Inc. # License:: Apache License, Version 2.0 # # 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. # class Chef class Resource class Group < Chef::Resource state_attrs :members description "Use the group resource to manage a local group." allowed_actions :create, :remove, :modify, :manage default_action :create property :group_name, String, name_property: true, identity: true, description: "The name of the group." property :gid, [ String, Integer ], description: "The identifier for the group." property :members, [String, Array], default: lazy { [] }, coerce: proc { |arg| arg.is_a?(String) ? arg.split(/\s*,\s*/) : arg }, description: "Which users should be set or appended to a group. This can be either an array or a comma separated list." property :excluded_members, [String, Array], default: lazy { [] }, coerce: proc { |arg| arg.is_a?(String) ? arg.split(/\s*,\s*/) : arg }, description: "Remove users from a group. May only be used when append is set to true." property :append, [ TrueClass, FalseClass ], default: false, description: "How members should be appended and/or removed from a group. When true, members are appended and excluded_members are removed. When false, group members are reset to the value of the members property." property :system, [ TrueClass, FalseClass ], default: false, description: "Sets the group to belong to the system group." property :non_unique, [ TrueClass, FalseClass ], default: false, description: "Allow gid duplication. May only be used with the Groupadd provider." alias_method :users, :members end end end