-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.rb
More file actions
143 lines (120 loc) · 2.71 KB
/
app.rb
File metadata and controls
143 lines (120 loc) · 2.71 KB
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
require 'sinatra'
require 'sinatra/activerecord'
require './config/environments' # database configuration
require './models/member'
if Sinatra::Base.environment == :development
require 'dotenv'
Dotenv.load
end
class NameValidator
def initialize(name, names)
@name = name.to_s
@names = names
@messages = []
end
def valid?
validate
@messages.empty?
end
def message
@messages.first
end
private
def validate
if @name.empty?
@messages << "You need to enter a name."
elsif @names.include?(@name)
@messages << "#{@name} is already included in our list."
end
end
end
helpers do
def protected!
return if authorized?
headers['WWW-Authenticate'] = 'Basic realm="Restricted Area"'
halt 401, "Not authorized\n"
end
def authorized?
@auth ||= Rack::Auth::Basic::Request.new(request.env)
@auth.provided? and @auth.basic? and @auth.credentials and @auth.credentials == [ENV['MEMBERS_USERNAME'], ENV['MEMBERS_PASSWORD']]
end
end
enable :sessions
get '/' do
redirect to('/members')
end
get '/login' do
protected!
redirect to('/members')
end
get '/members' do
@message = session.delete(:message)
@members = Member.all.order(:name)
erb :index
end
get '/members/new' do
protected!
@message = session.delete(:message)
@member = Member.new
erb :new
end
post '/members' do
protected!
@name = params[:name]
@members = Member.all
@names = []
@members.each do |member|
@names << member.name
end
validator = NameValidator.new(@name, @names)
if validator.valid?
@member = Member.new(params)
@member.save
session[:message] = "Successfully stored the member #{@name}."
redirect "/members/#{@member.id}"
else
@message = validator.message
erb :new
end
end
get '/members/:id' do
@message = session.delete(:message)
@member = Member.find(params[:id])
erb :show
end
get '/members/:id/edit' do
protected!
@member = Member.find(params[:id])
erb :edit
end
put '/members/:id' do
protected!
@name = params[:name]
@members = Member.all
@names = []
@members.each do |member|
@names << member.name
end
validator = NameValidator.new(@name, @names)
if validator.valid?
@member = Member.find(params[:id])
@member.update(:name => params[:name])
session[:message] = "Successfully updated the member #{@name}."
redirect "/members/#{@member.id}"
else
@message = validator.message
erb :edit
end
end
get "/members/:id/delete" do
protected!
@member = Member.find(params[:id])
erb :delete
end
delete '/members/:id' do
protected!
@member = Member.find(params[:id])
@member.delete
session[:message] = "Successfully deleted."
redirect '/members'
end