Sinatra的助手功能

时间:2013-09-03 19:15:57

标签: ruby sinatra

我正在使用Sinatra来监控服务器。我需要读取主文件夹中的文件夹列表,以及每个文件夹中meta.xml的内容。这是所需的输出:

<folders>
    <folder 1>
        <meta.xml content>
    <folder 2>
        <meta.xml content>
<\folders>

这是我目前的代码:

require 'sinatra'
require 'json'
require 'haml'

get '/processed' do
    status 200
    meeting_dir="/home/default"
    Dir.entries(meeting_dir)
end

我对Sinatra打印get块中所有变量的值感到困惑。如果我想编写一个子函数getxml来生成xml,我应该把它放在哪里?

1 个答案:

答案 0 :(得分:2)

helper

require 'sinatra'
require 'json'
require 'haml'

helpers do
  def get_xml( *args )
    # your code here…
  end
end

get '/processed' do
  # getxml is available here
  status 200
  meeting_dir="/home/default"
  Dir.entries(meeting_dir)
end

现在,我假设您希望输出为XML,因此该路由不起作用,您将获得最后一个表达式的评估,该表达式当前为Dir.entries(meeting_dir)

设置view,然后使用Haml's list_of helper我们就可以输出值列表了:

#views/contents.haml

<folders>
  = list_of(@metas) do |meta|
   = "<#{meta.name}>"
     = meta.content
   = "</#{meta.name}>"
<\folders>

现在你需要一个@metas对象:

helpers do

  def get_xml( meeting_dir )
    dirs = Dir.entries(meeting_dir).reject{|e| e.start_with? "." }
    meta = Struct.new(:name, :content)
    dirs.each_with_object([]) do |d,metas|
      meta.name = d # it's up to you whether you 
                    # want the absolute or relative path here
      meta.content = File.read File.expand_path(File.join d, "meta.xml")
      metas << meta
    end
    # the return value of each_with_object
    # is the object, so no need for a return expression
  end
end

get '/processed', :provides => :xml do
  # status 200 <- this is not needed
  meeting_dir="/home/default"
  @metas = get_xml(meeting_dir)
  haml :contents, :layout => false
end

另请查看http://www.sinatrarb.com/intro.html#Conditionshttp://www.sinatrarb.com/intro.html#Named%20Templates。这应该会给你一些事情。