-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvhost_api_ui_app.rb
114 lines (100 loc) · 3.15 KB
/
vhost_api_ui_app.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
# frozen_string_literal: true
require 'bundler/setup'
require 'rest-client'
require 'restclient/components'
require 'rack/cache'
require 'sinatra'
require 'sinatra/contrib'
require 'sinatra/flash'
require 'tilt/haml'
require 'json'
require 'base64'
require 'securerandom'
require 'digest/sha1'
require 'sass'
require 'filesize'
Dir.glob('./app/classes/*.rb').each { |file| require file }
Dir.glob('./app/helpers/*.rb').each { |file| require file }
configure do
set :root, File.expand_path('app/', __dir__)
set :views, File.expand_path('app/views', __dir__)
set :jsdir, 'js'
set :cssdir, 'css'
enable :coffeescript
set :cssengine, 'scss'
set :start_time, Time.now
set :logging, false
set :public_folder, File.expand_path('app/public', __dir__)
# rubocop:disable Security/YAMLLoad
@appconfig = YAML.load(
File.read('config/appconfig.yml')
)[settings.environment.to_s]
# rubocop:enable Security/YAMLLoad
@appconfig.keys.each do |key|
set key, @appconfig[key]
end
use Rack::Deflater
RestClient.enable Rack::Cache,
metastore: 'file:./tmp/cache/meta',
entitystore: 'file:./tmp/cache/body'
include GenericHelpers
include APIHelpers
include UIHelpers
include FormHelpers
end
configure :development, :test do
require 'pry'
require 'better_errors'
set :show_exceptions, :after_handler
set :raise_errors, false
use BetterErrors::Middleware
BetterErrors.application_root = settings.root
BetterErrors.use_pry!
RestClient.enable Rack::CommonLogger
use Rack::Session::Cookie, secret: File.read('config/session.secret'),
key: settings.session[:key].to_s,
domain: settings.session[:domain].to_s,
expire_after: settings.session[:timeout],
path: settings.session[:path].to_s,
httponly: true
end
configure :production do
set :static_cache_control, [:public, :must_revalidate, :max_age => 3600 * 7 * 2]
set :show_exceptions, false
set :raise_errors, false
use Rack::Session::Cookie, secret: File.read('config/session.secret'),
key: settings.session[:key].to_s,
domain: settings.session[:domain].to_s,
expire_after: settings.session[:timeout],
path: settings.session[:path].to_s,
httponly: true,
secure: true,
same_site: 'None'
end
before do
@user = session[:user] unless session[:user].nil?
authenticate! unless request.path_info =~ %r{/(login|css|img)}
set_title
set_sidebar_title
end
Dir.glob('./app/controllers/*.rb').each { |file| require file }
get '/' do
response_digest, @result = api_query("users/#{@user[:id]}/quota_stats", {})
etag response_digest if session[:flash].nil? || session[:flash].empty?
haml :home, layout: :layout
end
get '/session' do
session.to_hash.to_json
end
get '/stats' do
haml :stats
end
get '/settings' do
haml :settings
end
not_found do
haml :not_found
end
error Errno::ENETUNREACH do
haml :api_unavailable
end