X-Git-Url: https://git.r.bdr.sh/rbdr/grita/blobdiff_plain/5573b3c2672a04d58a91ce1c74f9c543e14fb423..c194753dd738f88ce42442dc1510ac29980893e7:/grita.rb?ds=inline diff --git a/grita.rb b/grita.rb index eaf59a7..76f1c93 100644 --- a/grita.rb +++ b/grita.rb @@ -2,7 +2,11 @@ require 'sinatra' require 'haml' require 'less' require 'dm-core' +require 'dm-validations' require 'dm-timestamps' +require 'dm-migrations' +require 'rqr' +require 'rdiscount' #config set :haml, :format => :html5 @@ -13,15 +17,40 @@ get '/' do end post '/' do - @grito = Grito.first_or_create(:title => params[:title], :text => params[:text]) + @grito = Grito.new(:title => params[:title], :text => params[:text]) + @grito.save haml :index end +get '/qr/:grito.png' do + tmpfile = Tempfile.new('tmp') + tmpfile.close + rpr_filepath = tmpfile.path + '.png' + + RQR::QRCode.create do |qr| + qr.save('http://#{request.host}/'+params[:grito], rpr_filepath) + end + + buffer = File.open(rpr_filepath).read + + content_type 'image/png' + buffer +end + get '/style.css' do less :style end -not_found do +get '/:grito' do + @grito = Grito.first(:id => params[:grito].to_i(36)) + raise "Invalid Post" if @grito.nil? + + @markdown = RDiscount.new(@grito.text) + + haml :grito, :layout => :layoutmini +end + +error do haml :error end @@ -29,11 +58,14 @@ DataMapper.setup(:default, ENV['DATABASE_URL'] || 'mysql://root:root@localhost/g class Grito include DataMapper::Resource property :id, Serial - property :title, String, :required => true - property :text, Text, :required => true + property :title, String + property :text, Text property :created_at, DateTime - def geturl() + validates_presence_of :title, :message => "· Debes incluír un título." + validates_presence_of :text, :message => "· ¡No escribiste contenido!" + + def gethash() self.id.to_s(36) end end \ No newline at end of file