summaryrefslogtreecommitdiffstats
path: root/lib/puppet/provider/user/windows_adsi.rb
blob: 9250def5911ef8b26ac76fbb3639043dcbf958bb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
require 'puppet/util/adsi'

Puppet::Type.type(:user).provide :windows_adsi do
  desc "User management for Windows"

  defaultfor :operatingsystem => :windows
  confine :operatingsystem => :windows
  confine :feature => :microsoft_windows

  has_features :manages_homedir

  def user
    @user ||= Puppet::Util::ADSI::User.new(@resource[:name])
  end

  def groups
    user.groups.join(',')
  end

  def groups=(groups)
    user.set_groups(groups, @resource[:membership] == :minimum)
  end

  def create
    @user = Puppet::Util::ADSI::User.create(@resource[:name])
    [:comment, :home, :groups].each do |prop|
      send("#{prop}=", @resource[prop]) if @resource[prop]
    end
  end

  def exists?
    Puppet::Util::ADSI::User.exists?(@resource[:name])
  end

  def delete
    Puppet::Util::ADSI::User.delete(@resource[:name])
  end

  # Only flush if we created or modified a user, not deleted
  def flush
    @user.commit if @user
  end

  def comment
    user['Description']
  end

  def comment=(value)
    user['Description'] = value
  end

  def home
    user['HomeDirectory']
  end

  def home=(value)
    user['HomeDirectory'] = value
  end

  [:uid, :gid, :shell].each do |prop|
    define_method(prop) { nil }

    define_method("#{prop}=") do |v|
      warning "No support for managing property #{prop} of user #{@resource[:name]} on Windows"
    end
  end

  def self.instances
    Puppet::Util::ADSI::User.map { |u| new(:ensure => :present, :name => u.name) }
  end
end