mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-09-21 07:26:15 +08:00
54 lines
1.2 KiB
Ruby
54 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class MyModuleShareableLinksController < ApplicationController
|
|
before_action :load_my_module
|
|
before_action :load_shareable_link, only: %i(update destroy)
|
|
before_action :check_view_permissions, only: :show
|
|
before_action :check_manage_permissions, except: :show
|
|
|
|
def show
|
|
render json: @my_module.shareable_link
|
|
end
|
|
|
|
def create
|
|
@my_module.shareable_link.create!(
|
|
signed_id: @my_module.signed_id,
|
|
description: params[:description],
|
|
team: @my_module.team,
|
|
created_by: current_user
|
|
)
|
|
|
|
render json: @my_module.shareable_link
|
|
end
|
|
|
|
def update
|
|
@my_module.shareable_link.update!(
|
|
description: params[:description],
|
|
last_modified_by: current_user
|
|
)
|
|
|
|
render json: @my_module.shareable_link
|
|
end
|
|
|
|
def destroy
|
|
@my_module.shareable_link.destroy!
|
|
|
|
render json: {}
|
|
end
|
|
|
|
private
|
|
|
|
def load_my_module
|
|
@my_module = MyModule.find_by(id: params[:my_module_id])
|
|
render_404 unless @my_module
|
|
end
|
|
|
|
def check_view_permissions
|
|
render_403 unless can_view_my_module?(@my_module)
|
|
end
|
|
|
|
def check_manage_permissions
|
|
render_403 unless can_manage_my_module?(@my_module)
|
|
end
|
|
end
|