2017-06-02 1 views
0

Ich habe den Fehler unten erhalten, wenn ich versuche, eine meiner Anwendungen von http://localhost:3000/api/v1/oauth/applications zu löschen.NameError (nicht initialisierte Konstante Mongoid :: Relations :: Cascading :: DeleteAll):

Started DELETE "/api/v1/oauth/applications/5930bd2aa54dd321f7248178" for ::1 
at 2017-06-01 21:53:22 -0400 
Processing by Doorkeeper::ApplicationsController#destroy as HTML 
Parameters: {"utf8"=>"✓", 
"authenticity_token"=>"+IxdEDUYW65Hj99VUqdJ/rydjZjJE8CIFy7El5KuuZ0rf36wLE0M4qJxBUL61D1IeRW+VvgWw1o9ckXxpHBkVw==", "commit"=>"Destroy", "id"=>"5930bd2aa54dd321f7248178"} 
MONGODB | localhost:27017 | playco_development.find | STARTED | {"find"=>"oauth_applications", "filter"=>{"_id"=>BSON::ObjectId('5930bd2aa54dd321f7248178')}} 
MONGODB | localhost:27017 | playco_development.find | SUCCEEDED | 0.000784s 
Completed 500 Internal Server Error in 9ms 

NameError (uninitialized constant Mongoid::Relations::Cascading::DeleteAll): 
    activesupport (4.2.8) lib/active_support/inflector/methods.rb:263:in `const_get' 
    activesupport (4.2.8) lib/active_support/inflector/methods.rb:263:in `block in constantize' 
    activesupport (4.2.8) lib/active_support/inflector/methods.rb:259:in `each' 
    activesupport (4.2.8) lib/active_support/inflector/methods.rb:259:in `inject' 
    activesupport (4.2.8) lib/active_support/inflector/methods.rb:259:in `constantize' 
    activesupport (4.2.8) lib/active_support/core_ext/string/inflections.rb:66:in `constantize' 
    mongoid (5.2.1) lib/mongoid/relations/metadata.rb:98:in `cascade_strategy' 
    mongoid (5.2.1) lib/mongoid/relations/cascading.rb:30:in `block in cascade!' 

Hier sind die Edelsteine ​​ich verwende, die mongoid und Schienen relevant sind:

gem 'rails', '4.2.8' 
gem 'mongoid', '~> 5.2.1' 
gem 'doorkeeper-mongodb', github: 'doorkeeper-gem/doorkeeper-mongodb' 
gem "doorkeeper-grants_assertion", github: "doorkeeper-gem/doorkeeper-grants_assertion" 

Dies geschieht nur, wenn zu ‚zerstören‘ eine bestehende Anwendung von der Benutzeroberfläche zu versuchen.

Jede Hilfe würde sehr geschätzt werden.

Antwort

0

Das Problem stammte von gem 'doorkeeper-mongodb' erfordert gem 'doorkeeper' bei Version> = 4.00. Eine Version von gem 'doorkeeper' größer als v3.1.0 hat eine dependent: :delete_all Assoziation (siehe Doorkeeper/lib/doorkeeper/models/application_mixin.rb innerhalb der Doorkeeper Gem-Datei). Eine kaskadierende Relation von :delete_all wird in keiner der bisherigen Versionen von Mongoid unterstützt und löst die Ausnahme NameError aus.

Ich kam um dies mit gem 'doorkeeper', '~> 3.1.0'. Dies führte jedoch zu einem Edelsteinabhängigkeitsproblem mit gem 'doorkeeper-grants_assertion', das ich durch Anforderung einer bestimmten Festschreibungsversion in meiner Schmuckstückdatei wie unten beschrieben behoben hatte:

gem 'mongoid', '~> 5.1.0' 
gem 'doorkeeper-mongodb', github: 'doorkeeper-gem/doorkeeper-mongodb' 
gem 'doorkeeper', '~> 3.1.0' 
gem 'doorkeeper-grants_assertion', github: "doorkeeper-gem/doorkeeper- 
grants_assertion", :ref => 'f4391f2f07d96845db0d9dd6889f58d4bd4d23bb' 
Verwandte Themen