How to add High Voltage static pages to your sitemap file
High Voltage is a fantastic gem for adding static pages to your Rails app. I’m using it extensively on a project that has a large number of static, style-heavy pages that don’t make sense to serve from the database.
The other day my client asked me to add a sitemap XML file to the app that Google could consume (this is something that you can set up under Google Webmaster Tools that is supposed to help with site indexing).
I checked out several approaches for building sitemaps in a Rails app and settled on using the SitemapGenerator gem. This gem allows you to easily create paths to ActiveRecord resources. For example, if you want your sitemap to include all the FAQ pages you have, you could do something like this in the config file:
Faq.published.find_each do |faq|
add faq_path(faq), lastmod: faq.updated_at
end
But there’s no built-in way to include all your High Voltage static pages, as High Voltage doesn’t currently offer a way to get a list of all your pages.
So, I wrote a class you can put in your lib folder to do just that:
require 'find'
class HighVoltagePages
attr_reader :pages
def initialize(ministry)
@pages = get_pages
end
private
def get_pages
pages = []
Find.find(content_path) do |f|
pages.push url_path(f) if !directory?(f) && html?(f) && !partial?(f)
end
pages
end
def url_path(f)
f.gsub(content_path, '').gsub(file_pattern, '')
end
def directory?(f)
FileTest.directory?(f)
end
def partial?(f)
File.basename(f).first == "_"
end
def html?(f)
f.match(file_pattern)
end
def content_path
Rails.root.join('app', 'views', HighVoltage.content_path).to_s
end
def file_pattern
/\.(html)(\.[a-z]+)?$/
end
end
Now all you have to do in your sitemap config file is iterate over those pages:
HighVoltagePages.new.pages.each do |page|
add page
end
Need help building or maintaining a Rails app?
Jeremy is currently booked until mid-2023, but always happy to chat.