Чтобы обновить элемент в поле массива, вы можете использовать positional $ operator
Например, следующие js приращения c от 3 до 4 для _id 341445:
db.collection.update({a:1, "b._id":341445} , {$inc:{"b.$.c":1}})
Вы могли бы, чтобы MyMiddleware проверял путь и не передавал управление следующему элементу промежуточного ПО, если он совпадает.
class MyMiddleware
def initialize app
@app = app
end
def call env
middlewary_stuff if env['PATH_INFO'] == '/foo'
@app.call env
end
def middlewary_stuff
#...
end
end
Или, вы можете использовать URLMap без dslness. Это выглядело бы примерно так:
main_app = MainApp.new
Rack::URLMap.new '/'=>main_app, /^(foo|bar)/ => MyMiddleWare.new(main_app)
URLMap на самом деле довольно прост в использовании .
Это не работает, потому что @app
не существует в нужной области:
# in my_app.ru or any Rack::Builder context:
@app = self
map '/foo' do
use MyMiddleware
run lambda { |env| @app.call(env) }
end
Но это будет:
# in my_app.ru or any Rack::Builder context:
::MAIN_RACK_APP = self
map '/foo' do
use MyMiddleware
run lambda { |env| ::MAIN_RACK_APP.call(env) }
end
Rack::Builder
лишает первый аргумент map
от передней части пути, так что он не будет бесконечно повторяться. К сожалению, это означает, что после удаления префикса пути маловероятно, что остальная часть пути будет правильно соответствовать другим сопоставлениям.
Вот пример:
::MAIN_APP = self
use Rack::ShowExceptions
use Rack::Lint
use Rack::Reloader, 0
use Rack::ContentLength
map '/html' do
use MyContentTypeSettingMiddleware, 'text/html'
run lambda { |env| puts 'HTML!'; ::MAIN_APP.call(env) }
end
map '/xml' do
use MyContentTypeSettingMiddleware, 'application/xml'
run lambda { |env| puts 'XML!'; ::MAIN_APP.call(env) }
end
map '/' do
use ContentType, 'text/plain'
run lambda { |env| [ 200, {}, "<p>Hello!</p>" ] }
end
Переход к /html/xml
приводит к тому, что в журнал попадает следующее:
HTML!
XML!
127.0.0.1 - - [28/May/2009 17:41:42] "GET /html/xml HTTP/1.1" 200 13 0.3626
То есть приложение сопоставляется с полосами '/html'
префикса '/html'
, и вызов теперь соответствует приложению, сопоставленному с '/xml'
.