# limitations under the License.
#
+require "json"
+
include_recipe "apache::ssl"
+include_recipe "passenger"
include_recipe "git"
package "libsqlite3-dev"
package "g++"
package "sqlite3"
+package "osmosis"
+package "curl"
+package "subversion"
package "ruby"
package "rubygems"
gem_package "sinatra-r18n"
gem_package "rack-contrib"
-apache_module "passenger"
+apache_module "cache"
+apache_module "disk_cache"
+
+template "/etc/cron.d/taginfo" do
+ source "cron.erb"
+ owner "root"
+ group "root"
+ mode 0644
+end
+
+directory "/var/log/taginfo" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+end
-munin_plugin "passenger_memory"
-munin_plugin "passenger_processes"
-munin_plugin "passenger_queues"
-munin_plugin "passenger_requests"
+file "/etc/logrotate.d/taginfo" do
+ action :delete
+end
node[:taginfo][:sites].each do |site|
name = site[:name]
icon = site[:icon]
contact = site[:contact]
+ directory "/var/log/taginfo/#{name}" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
directory directory do
owner "taginfo"
group "taginfo"
git "#{directory}/osmium" do
action :sync
repository "git://github.com/joto/osmium.git"
- revision "master"
+ revision "osmorg-taginfo-live"
user "taginfo"
group "taginfo"
end
git "#{directory}/taginfo" do
action :sync
repository "git://github.com/joto/taginfo.git"
- revision "master"
+ revision "osmorg-taginfo-live"
user "taginfo"
group "taginfo"
end
- settings = edit_file "#{directory}/taginfo/taginfo-config-example.json" do |line|
- line.gsub!(/^( *)"url": ".*",/, "\\1\"url\": \"http://#{name}/\",")
- line.gsub!(/^( *)"description": ".*Change this text.*,/, "\\1\"description\": \"#{description}\",")
- line.gsub!(/^( *)"icon": ".*",/, "\\1\"icon\": \"/img/logo/#{icon}.png\",")
- line.gsub!(/^( *)"contact": "Anonymous",/, "\\1\"contact\": \"#{contact}\",")
- line.gsub!(/^( *)"shortname": ".*",/, "\\1\"shortname\": \"Taginfo\",")
- line.gsub!(/^( *)"contact": "somebody@example.com",/, "\\1\"contact\": \"webmaster@openstreetmap.org\",")
- line.gsub!(/^( *)"cxxflags": ".*",/, "\\1\"cxxflags\": \"-I../../osmium/include\",")
-
- line
- end
+ settings = JSON.parse(IO.read("#{directory}/taginfo/taginfo-config-example.json"))
+
+ settings["instance"]["url"] = "http://#{name}/"
+ settings["instance"]["description"] = description
+ settings["instance"]["icon"] = "/img/logo/#{icon}.png"
+ settings["instance"]["contact"] = contact
+ settings["logging"]["directory"] = "/var/log/taginfo/#{name}"
+ settings["opensearch"]["shortname"] = "Taginfo"
+ settings["opensearch"]["contact"] = "webmaster@openstreetmap.org"
+ settings["sources"]["download"] = ""
+ settings["sources"]["create"] = "db languages josm potlatch wiki"
+ settings["sources"]["db"]["planetfile"] = "#{directory}/planet/planet.pbf"
+ settings["sources"]["db"]["tagstats"] = "#{directory}/taginfo/tagstats/tagstats"
+ settings["tagstats"]["cxxflags"] = "-I../../osmium/include"
file "#{directory}/taginfo-config.json" do
owner "taginfo"
group "taginfo"
mode 0644
- content settings
+ content JSON.pretty_generate(settings)
end
execute "#{directory}/taginfo/tagstats/Makefile" do
notifies :restart, "service[apache2]"
end
+ directory "#{directory}/taginfo/web/tmp" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
directory "#{directory}/data" do
owner "taginfo"
group "taginfo"
mode 0755
end
+ directory "#{directory}/data/old" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ directory "#{directory}/download" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ directory "#{directory}/sources" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ directory "#{directory}/planet" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ remote_file "#{directory}/planet/planet.pbf" do
+ action :create_if_missing
+ source "http://planet.openstreetmap.org/pbf/planet-latest.osm.pbf"
+ owner "taginfo"
+ group "taginfo"
+ mode 0644
+ end
+
+ directory "#{directory}/planet/log" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ directory "#{directory}/planet/replication" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ template "#{directory}/planet/replication/configuration.txt" do
+ source "configuration.txt.erb"
+ owner "taginfo"
+ group "taginfo"
+ mode 0644
+ end
+
+ file "#{directory}/planet/replication/download.lock" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0644
+ end
+
+ directory "#{directory}/bin" do
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ end
+
+ template "#{directory}/bin/update-planet" do
+ source "update-planet.erb"
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ variables :directory => directory
+ end
+
+ template "#{directory}/bin/update-taginfo" do
+ source "update-taginfo.erb"
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ variables :directory => directory
+ end
+
+ template "#{directory}/bin/update" do
+ source "update.erb"
+ owner "taginfo"
+ group "taginfo"
+ mode 0755
+ variables :name => name, :directory => directory
+ end
+
apache_site name do
template "apache.erb"
directory "#{directory}/taginfo/web/public"