1 class Pettanr.History extends Backbone.History
\r
5 if Pettanr.History.lock_url
\r
6 if confirm('leave? edit data unsaved')
\r
7 Pettanr.History.lock_url = null
\r
9 @history.pushState({}, document.title, '/' + Pettanr.History.lock_url)
\r
13 Backbone.history = new Pettanr.History
\r
14 class Pettanr.Router extends Backbone.Router
\r
16 initialize: (options) ->
\r
18 _.extend(this, Backbone.Events)
\r
19 @operators = options.operators
\r
21 parse_query_string: (query_string) ->
\r
24 ary = _.map decodeURI(query_string).split(/&/g), (el, i) ->
\r
39 {route: '', callback: 'home'},
\r
40 {route: 'top/:action', callback: 'top_a'},
\r
41 {route: 'users/:action', callback: 'users_a'}, # no manifest route
\r
42 {route: 'user_sessions/:action', callback: 'user_sessions_a'}, # no manifest route
\r
43 {route: ':controller/:id/:action?*query_string', callback: 'c_i_a'},
\r
44 {route: ':controller/:id/:action', callback: 'c_i_a'},
\r
45 {route: ':controller/:id?*query_string', callback: 'c_i'},
\r
46 {route: ':controller/:id', callback: 'c_i'},
\r
47 {route: ':controller?*query_string', callback: 'c'},
\r
48 {route: ':controller', callback: 'c'},
\r
51 find_route: (url) ->
\r
53 _.any @peta_routes(), (route) =>
\r
54 route.regex = @_routeToRegExp(route.route)
\r
55 if route.regex.test(url)
\r
59 url_to_params: (url) ->
\r
60 if route = @find_route(url)
\r
61 args = @_extractParameters(route.regex, url)
\r
62 n = route.callback # callback function name by string
\r
63 this[n + '_params'].apply(this, args) # call to c_i_a_params, c_i_params, c_params
\r
69 Pettanr.ActionFilter.sns_filters()
\r
71 Pettanr.ActionFilter.blog_filters()
\r
73 my_filters: (role, params) ->
\r
75 c = f[params['controller']] || {}
\r
79 # return false if allow
\r
80 # return true if deny
\r
81 authenticate: (role, params) ->
\r
83 if not @operators[n]() # ex: operators.is_user()
\r
84 filter = @my_filters(role, params)
\r
85 if Pettanr.before_filter(params['action'], filter)
\r
90 # return sign in form if invalid url
\r
91 # return null if url is valid
\r
93 return @guest_url() if @authenticate('reader', params) or @authenticate('resource_reader', params) or @authenticate('user', params)
\r
94 return @new_author_url() if @authenticate('author', params)
\r
95 return @new_artist_url() if @authenticate('artist', params)
\r
101 new_author_url: () ->
\r
104 new_artist_url: () ->
\r
107 # render App(render:all)
\r
109 params = @home_params()
\r
110 @trigger('go', params)
\r
114 params['controller'] = 'folders'
\r
115 params['action'] = 'root'
\r
118 # controller/id/action case
\r
119 # ex) scrolls/3/edit
\r
120 c_i_a: (controller, id, action, query_string, form) ->
\r
121 params = @c_i_a_params(controller, id, action, query_string)
\r
122 if safe_url = @block(params)
\r
123 @trigger('deny', params, form, safe_url)
\r
125 @trigger('go', params, form)
\r
127 c_i_a_params: (controller, id, action, query_string) ->
\r
128 params = @parse_query_string(query_string)
\r
129 params['controller'] = controller
\r
130 params['format'] = 'html'
\r
133 params['format'] = t[1]
\r
135 t = action.split('.')
\r
137 params['format'] = t[1]
\r
139 if Pettanr.is_number(action)
\r
140 params['action'] = id
\r
141 params['id'] = action
\r
143 params['action'] = action
\r
147 # controller and id case
\r
149 c_i: (controller, id, query_string, form) ->
\r
150 params = @c_i_params(controller, id, query_string)
\r
151 if safe_url = @block(params)
\r
152 @trigger('deny', params, form, safe_url)
\r
154 @trigger('go', params, form)
\r
156 c_i_params: (controller, id, query_string) ->
\r
157 params = @parse_query_string(query_string)
\r
158 params['controller'] = controller
\r
159 params['format'] = 'html'
\r
162 params['format'] = t[1]
\r
164 if Pettanr.is_number(id)
\r
165 params['action'] = 'show'
\r
169 params['action'] = id
\r
171 params['action'] = 'index'
\r
174 # controller only case
\r
176 c: (controller, query_string, form) ->
\r
177 params = @c_params(controller, query_string)
\r
178 if safe_url = @block(params)
\r
179 @trigger('deny', params, form, safe_url)
\r
181 @trigger('go', params, form)
\r
183 c_params: (controller, query_string) ->
\r
184 params = @parse_query_string(query_string)
\r
185 params['controller'] = controller
\r
186 params['format'] = 'html'
\r
187 params['action'] = 'index'
\r
190 top_a: (action, query_string, form) ->
\r
191 params = @users_a_params(action, query_string)
\r
192 if safe_url = @block(params)
\r
193 @trigger('deny', params, safe_url)
\r
195 @trigger('go', params, form)
\r
197 top_a_params: (action, query_string) ->
\r
198 params = @parse_query_string(query_string)
\r
199 params['controller'] = 'top'
\r
200 params['format'] = 'html'
\r
201 params['action'] = action
\r
204 user_sessions_a: (action, query_string, form) ->
\r
205 params = @user_sessions_a_params(action, query_string)
\r
206 if safe_url = @block(params)
\r
207 @trigger('deny', params, safe_url)
\r
209 @trigger('go', params, form)
\r
211 user_sessions_a_params: (action, query_string) ->
\r
212 params = @parse_query_string(query_string)
\r
213 params['controller'] = 'user_sessions'
\r
214 params['format'] = 'html'
\r
215 params['action'] = action
\r
218 users_a: (action, query_string, form) ->
\r
219 params = @users_a_params(action, query_string)
\r
220 if safe_url = @block(params)
\r
221 @trigger('deny', params, safe_url)
\r
223 @trigger('go', params, form)
\r
225 users_a_params: (action, query_string) ->
\r
226 params = @parse_query_string(query_string)
\r
227 params['controller'] = 'users'
\r
228 params['format'] = 'html'
\r
229 params['action'] = action
\r
232 class Pettanr.GlobalRouter extends Pettanr.Router
\r
234 initialize: (options) ->
\r
236 _.each @peta_routes(), (r) =>
\r
237 @route(r.route, r.callback)
\r
239 class Pettanr.LocalRouter extends Pettanr.Router
\r
241 initialize: (options) ->
\r
245 navigate: (url, form) ->
\r
246 if route = @find_route(url)
\r
247 args = @_extractParameters(route.regex, url)
\r
249 n = route.callback # callback function name by string
\r
250 this[n].apply(this, args) # call to c_i_a, c_i, c
\r