Merge pull request #14 from webfactory/fix_10788
[puppet_vcsrepo.git] / lib / puppet / type / vcsrepo.rb
1 require 'pathname'
2
3 Puppet::Type.newtype(:vcsrepo) do
4   desc "A local version control repository"
5
6   feature :gzip_compression,
7           "The provider supports explicit GZip compression levels"
8   feature :basic_auth,
9           "The provider supports HTTP Basic Authentication"
10   feature :bare_repositories,
11           "The provider differentiates between bare repositories
12           and those with working copies",
13           :methods => [:bare_exists?, :working_copy_exists?]
14
15   feature :filesystem_types,
16           "The provider supports different filesystem types"
17
18   feature :reference_tracking,
19           "The provider supports tracking revision references that can change
20            over time (eg, some VCS tags and branch names)"
21
22   feature :ssh_identity,
23           "The provider supports a configurable SSH identity file"
24
25   feature :modules,
26           "The repository contains modules that can be chosen of"
27
28   ensurable do
29     attr_accessor :latest
30
31     def insync?(is)
32       @should ||= []
33
34       case should
35         when :present
36           return true unless [:absent, :purged, :held].include?(is)
37         when :latest
38           if is == :latest
39             return true
40           else
41             return false
42           end
43       end
44     end
45
46     newvalue :present do
47       provider.create
48     end
49
50     newvalue :bare, :required_features => [:bare_repositories] do
51       provider.create
52     end
53
54     newvalue :absent do
55       provider.destroy
56     end
57
58     newvalue :latest, :required_features => [:reference_tracking] do
59       if provider.exists?
60         if provider.respond_to?(:update_references)
61           provider.update_references
62         end
63         if provider.respond_to?(:latest?)
64             reference = provider.latest || provider.revision
65         else
66           reference = resource.value(:revision) || provider.revision
67         end
68         notice "Updating to latest '#{reference}' revision"
69         provider.revision = reference
70       else
71         provider.create
72       end
73     end
74
75     def retrieve
76       prov = @resource.provider
77       if prov
78         if prov.working_copy_exists?
79           (@should.include?(:latest) && prov.latest?) ? :latest : :present
80         elsif prov.class.feature?(:bare_repositories) and prov.bare_exists?
81           :bare
82         else
83           :absent
84         end
85       else
86         raise Puppet::Error, "Could not find provider"
87       end
88     end
89
90   end
91
92   newparam(:path) do
93     desc "Absolute path to repository"
94     isnamevar
95     validate do |value|
96       path = Pathname.new(value)
97       unless path.absolute?
98         raise ArgumentError, "Path must be absolute: #{path}"
99       end
100     end
101   end
102
103   newparam(:source) do
104     desc "The source URI for the repository"
105   end
106
107   newparam(:fstype, :required_features => [:filesystem_types]) do
108     desc "Filesystem type"
109   end
110
111   newproperty(:revision) do
112     desc "The revision of the repository"
113     newvalue(/^\S+$/)
114   end
115
116   newparam(:owner) do
117     desc "The user/uid that owns the repository files"
118   end
119
120   newparam(:group) do
121     desc "The group/gid that owns the repository files"
122   end
123
124   newparam(:excludes) do
125     desc "Files to be excluded from the repository"
126   end
127
128   newparam(:force) do
129     desc "Force repository creation, destroying any files on the path in the process."
130     newvalues(:true, :false)
131     defaultto false
132   end
133
134   newparam :compression, :required_features => [:gzip_compression] do
135     desc "Compression level"
136     validate do |amount|
137       unless Integer(amount).between?(0, 6)
138         raise ArgumentError, "Unsupported compression level: #{amount} (expected 0-6)"
139       end
140     end
141   end
142
143   newparam :basic_auth_username, :required_features => [:basic_auth] do
144     desc "HTTP Basic Auth username"
145   end
146
147   newparam :basic_auth_password, :required_features => [:basic_auth] do
148     desc "HTTP Basic Auth password"
149   end
150
151   newparam :identity, :required_features => [:ssh_identity] do
152     desc "SSH identity file"
153   end
154   
155   newparam :module, :required_features => [:modules] do
156     desc "The repository module to manage"
157   end
158 end