簡體   English   中英

語法錯誤,非預期的'(',需要keyword_end

[英]syntax error, unexpected '(', expecting keyword_end

我是一個初學者...出現以下錯誤:

SyntaxError - syntax error, unexpected '(', expecting keyword_end
            authorize @vote, :update?(user, record)
                                      ^
/Users/louismorin/code/CP299/app/controllers/votes_controller.rb:28: syntax error, unexpected ')', expecting '=':
  app/controllers/votes_controller.rb:28:in `'
  activesupport (4.0.5) lib/active_support/dependencies.rb:424:in `block in load_file'
  activesupport (4.0.5) lib/active_support/dependencies.rb:616:in `new_constants_in'
  activesupport (4.0.5) lib/active_support/dependencies.rb:423:in `load_file'
  activesupport (4.0.5) lib/active_support/dependencies.rb:324:in `require_or_load'
  activesupport (4.0.5) lib/active_support/dependencies.rb:463:in `load_missing_constant'
  activesupport (4.0.5) lib/active_support/dependencies.rb:184:in `const_missing'
  activesupport (4.0.5) lib/active_support/inflector/methods.rb:226:in `block in constantize'
  activesupport (4.0.5) lib/active_support/inflector/methods.rb:224:in `constantize'
  activesupport (4.0.5) lib/active_support/dependencies.rb:535:in `get'
  activesupport (4.0.5) lib/active_support/dependencies.rb:566:in `constantize'
  actionpack (4.0.5) lib/action_dispatch/routing/route_set.rb:76:in `controller_reference'
  actionpack (4.0.5) lib/action_dispatch/routing/route_set.rb:66:in `controller'
  actionpack (4.0.5) lib/action_dispatch/routing/route_set.rb:44:in `call'
  actionpack (4.0.5) lib/action_dispatch/journey/router.rb:71:in `block in call'
  actionpack (4.0.5) lib/action_dispatch/journey/router.rb:59:in `call'
  actionpack (4.0.5) lib/action_dispatch/routing/route_set.rb:674:in `call'
  warden (1.2.3) lib/warden/manager.rb:35:in `block in call'
  warden (1.2.3) lib/warden/manager.rb:34:in `call'
  rack (1.5.2) lib/rack/etag.rb:23:in `call'
  rack (1.5.2) lib/rack/conditionalget.rb:35:in `call'
  rack (1.5.2) lib/rack/head.rb:11:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/params_parser.rb:27:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/flash.rb:241:in `call'
  rack (1.5.2) lib/rack/session/abstract/id.rb:225:in `context'
  rack (1.5.2) lib/rack/session/abstract/id.rb:220:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/cookies.rb:486:in `call'
  activerecord (4.0.5) lib/active_record/query_cache.rb:36:in `call'
  activerecord (4.0.5) lib/active_record/connection_adapters/abstract/connection_pool.rb:626:in `call'
  activerecord (4.0.5) lib/active_record/migration.rb:373:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/callbacks.rb:29:in `block in call'
  activesupport (4.0.5) lib/active_support/callbacks.rb:373:in `_run__3205659148210679757__call__callbacks'
  activesupport (4.0.5) lib/active_support/callbacks.rb:80:in `run_callbacks'
  actionpack (4.0.5) lib/action_dispatch/middleware/callbacks.rb:27:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/reloader.rb:64:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/remote_ip.rb:76:in `call'
  better_errors (2.0.0) lib/better_errors/middleware.rb:84:in `protected_app_call'
  better_errors (2.0.0) lib/better_errors/middleware.rb:79:in `better_errors_call'
  better_errors (2.0.0) lib/better_errors/middleware.rb:57:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/debug_exceptions.rb:17:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
  railties (4.0.5) lib/rails/rack/logger.rb:38:in `call_app'
  railties (4.0.5) lib/rails/rack/logger.rb:20:in `block in call'
  activesupport (4.0.5) lib/active_support/tagged_logging.rb:68:in `block in tagged'
  activesupport (4.0.5) lib/active_support/tagged_logging.rb:26:in `tagged'
  activesupport (4.0.5) lib/active_support/tagged_logging.rb:68:in `tagged'
  railties (4.0.5) lib/rails/rack/logger.rb:20:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/request_id.rb:21:in `call'
  rack (1.5.2) lib/rack/methodoverride.rb:21:in `call'
  rack (1.5.2) lib/rack/runtime.rb:17:in `call'
  activesupport (4.0.5) lib/active_support/cache/strategy/local_cache.rb:83:in `call'
  rack (1.5.2) lib/rack/lock.rb:17:in `call'
  actionpack (4.0.5) lib/action_dispatch/middleware/static.rb:64:in `call'
  rack (1.5.2) lib/rack/sendfile.rb:112:in `call'
  railties (4.0.5) lib/rails/engine.rb:511:in `call'
  railties (4.0.5) lib/rails/application.rb:97:in `call'
  rack (1.5.2) lib/rack/lock.rb:17:in `call'
  rack (1.5.2) lib/rack/content_length.rb:14:in `call'
  rack (1.5.2) lib/rack/handler/webrick.rb:60:in `service'
  /Users/louismorin/.rbenv/versions/2.1.2/lib/ruby/2.1.0/webrick/httpserver.rb:138:in `service'
  /Users/louismorin/.rbenv/versions/2.1.2/lib/ruby/2.1.0/webrick/httpserver.rb:94:in `run'
  /Users/louismorin/.rbenv/versions/2.1.2/lib/ruby/2.1.0/webrick/server.rb:295:in `block in start_thread'

Here is my code for votes_controller.rb:

        class VotesController < ApplicationController
            before_action :load_post_and_vote


            def up_vote
                # http://apidock.com/rails/ActionController/Base/redirect_to
                update_vote!(1)
                redirect_to :back
            end

            def down_vote
                update_vote!(-1)
                redirect_to :back
            end

            private

            def load_post_and_vote
                # extract into this method the definition of @post and @vote
                @post = Post.find(params[:post_id])
                @vote = @post.votes.where(user_id: current_user)
            end

            def update_vote!(new_value)
                # Extract vote updating/creating logic here.
            # This method has access to @vote, because of the before_action
            if @vote
              authorize @vote, :update?(user, record)
              @vote.update_attribute(:value, 1)
            else
              @vote = current_user.votes.build(value: 1, post: @post)
              authorize @vote, :create?
              @vote.save
            end
          end
    end

我正在嘗試調用此方法:

def update?(user, record)
    can_moderate?
  end

當我從:update刪除(用戶,記錄)時? 我收到錯誤數量的參數錯誤。 當我嘗試在主題頁面上為帖子發帖時,我遇到此錯誤。

謝謝你的幫助...

我正在使用Pundit進行authorize

class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  include Pundit
  protect_from_forgery with: :exception
    before_action :configure_permitted_parameters, if: :devise_controller?


      rescue_from Pundit:NotAuthorizedError do |exception|
        redirect_to root_url, alert: exception.message
      end

    protected

    def configure_permitted_parameters
      devise_parameter_sanitizer.for(:sign_up) << :name
    end
end

Pundit使用recorduser參數initializes其策略對象,但是隨后調用不帶參數的方法。 update? ApplicationPolicy類中的方法。 它可能不需要參數。

為了解決這個問題,只需feed authorize對象和方法為符號( :update? )。 (通過getter方法將記錄和用戶作為實例變量“傳遞”)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM