Warum funktioniert „Friendly_id“ bei einer Aktion und schlägt bei einer anderen fehl?

StackOverflow https://stackoverflow.com//questions/23050444

  •  21-12-2019
  •  | 
  •  

Frage

Ich habe einige benutzerdefinierte Aktionen in meinem orders_controller.rb:

class OrdersController < ApplicationController
  def process_payment
    @order = Order.friendly.find(params[:id])
    [snip]
    binding.pry_remote # drops into the terminal here for debugging
    redirect_to order_path(@order)
    [snip]
  end
end

Testivate::Application.routes.draw do
  resources :orders do
    member do
      get :pay
      post :process_payment
    end
  end
end

Ich kann im Terminal sehen, dass innerhalb der @order#process_payment Aktion, friendly_id funktioniert:

[1] pry(#<OrdersController>)> @order
+----+-------+-------+------+------+------+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| id | co... | url   | comp | comp | comp | us... | gu... | gu... | cr... | up... | pr... | uuid  | sp... | payed |
+----+-------+-------+------+------+------+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 1  | Th... | ht... | http | http | http | 1     |       |       | 20... | 20... | 1     | ee... | true  | false |
+----+-------+-------+------+------+------+-------+-------+-------+-------+-------+-------+-------+-------+-------+
1 row in set
[2] pry(#<OrdersController>)> @order.uuid
=> "ee1bbe01-e1ca-420c-991b-76ce90525cf8"
[3] pry(#<OrdersController>)> request.original_url
=> "http://127.0.0.1:4000/orders/ee1bbe01-e1ca-420c-991b-76ce90525cf8/process_payment"
[4] pry(#<OrdersController>)> order_path(@order)
=> "/orders/ee1bbe01-e1ca-420c-991b-76ce90525cf8"

Aber wenn @order#process_payment versucht weiterzuleiten @order#show, es schlägt fehl.

Ich erhalte die Fehlermeldung:

ActiveRecord::RecordNotFound at /orders/ee1bbe01-e1ca-420c-991b-76ce90525cf8
Couldn't find Order with id=ee1bbe01-e1ca-420c-991b-76ce90525cf8

Aber seltsamerweise scheint dieser Fehler aufzutreten, bevor Rails versucht, den Vorgang abzuschließen @order#show, da es in meinem Inneren nie zum Terminal herunterfällt @order#show Aktion:

class OrdersController < ApplicationController
  def show
    binding.pry_remote # should drop down to terminal here for debugging, but we never get this far
    @order = Order.friendly.find(params[:id])
    respond_with @order
  end
end

Warum ist das?

Anderer potenziell relevanter Code:

class Order < ActiveRecord::Base
  extend FriendlyId
  friendly_id :uuid
  after_create :generate_uuid  
  def generate_uuid
    self.update_attributes :uuid => SecureRandom.uuid
  end
end

Verwendung von Rails 4.0.2 und Friendly_id 5.0.3.

War es hilfreich?

Lösung

Sie werden sich das ansehen wollen:

friendly_id :uuid, use: [:slugged, :finders]

Dies legt grundsätzlich den Standardwert fest find Methode von Rails, um sowohl nach dem Standard zu suchen id und das slug.Ich denke, das wird Ihr Problem lösen

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top