require 'emot'
module TDiary
module RequestExtension
# backward compatibility, returns NOT mobile phone always
def mobile_agent?
false
end
# backward compatibility, returns NOT smartphone always
def smartphone?
false
end
end
end
=begin
== String class
enhanced String class
=end
class String
def make_link
r = %r<(((http[s]{0,1}|ftp)://[\(\)%#!/0-9a-zA-Z_$@.&+-,'"*=;?:~-]+)|([0-9a-zA-Z_.-]+@[\(\)%!0-9a-zA-Z_$.&+-,'"*-]+\.[\(\)%!0-9a-zA-Z_$.&+-,'"*-]+))>
return self.
gsub( / /, "\001" ).
gsub( /, "\002" ).
gsub( />/, "\003" ).
gsub( /&/, '&' ).
gsub( /\"/, "\004").
gsub( r ){ $1 == $2 ? "#$2" : "#$4" }.
gsub( /\004/, '"' ).
gsub( /\003/, '>' ).
gsub( /\002/, '<' ).
gsub( /^\001+/ ) { $&.gsub( /\001/, ' ' ) }.
gsub( /\001/, ' ' ).
gsub( /\t/, ' ' * 8 )
end
def emojify
self.to_str.gsub(/:([a-zA-Z0-9_+-]+):/) do |match|
emoji_alias = $1.downcase
emoji_url = %Q[]
if emoji_alias == 'plus1' or emoji_alias == '+1'
emoji_url % (['plus1']*3)
elsif Emot.unicode(emoji_alias)
emoji_url % ([CGI.escape(emoji_alias)]*3)
else
match
end
end
end
end
=begin
== CGI class
enhanced CGI class
=end
class CGI
include TDiary::RequestExtension
def valid?( param, idx = 0 )
self.params[param] and self.params[param][idx] and self.params[param][idx].length > 0
end
def https?
return true if env_table['HTTP_X_FORWARDED_PROTO'] == 'https'
return false if env_table['HTTPS'].nil? or /off/i =~ env_table['HTTPS'] or env_table['HTTPS'] == ''
true
end
def request_uri
_request_uri = env_table['REQUEST_URI']
_script_name = env_table['SCRIPT_NAME']
if !_request_uri || _request_uri == '' || _request_uri == _script_name then
_path_info = env_table['PATH_INFO'] || ''
_query_string = env_table['QUERY_STRING'] || ''
# Workaround for IIS-style PATH_INFO ('/dir/script.cgi/path', not '/path')
# See http://support.microsoft.com/kb/184320/
_request_uri = _path_info.include?(_script_name) ? '' : _script_name.dup
_request_uri << _path_info
_request_uri << '?' + _query_string if _query_string != ''
end
_request_uri
end
def redirect_url
env_table['REDIRECT_URL']
end
def base_url
return '' unless script_name
begin
script_dirname = script_name.empty? ? '' : File::dirname(script_name)
if https?
port = (server_port == 443) ? '' : ':' + server_port.to_s
"https://#{server_name}#{port}#{script_dirname}/"
else
port = (server_port == 80) ? '' : ':' + server_port.to_s
"http://#{server_name}#{port}#{script_dirname}/"
end.sub(%r|/+$|, '/')
rescue SecurityError
''
end
end
end
class RackCGI < CGI; end
=begin
== Safe module
=end
module Safe
def safe
result = nil
if $SAFE < 1 then
Proc.new {
begin
$SAFE = 1
ensure
result = yield
end
}.call
else
result = yield
end
result
end
module_function :safe
end
# Local Variables:
# mode: ruby
# indent-tabs-mode: t
# tab-width: 3
# ruby-indent-level: 3
# End:
# vim: ts=3