mirror of
https://github.com/discourse/discourse.git
synced 2026-03-04 01:15:08 +08:00
There exists a `localization_guardian` that checks if a user can localize based on settings like - `content_localization_allowed_groups` - `content_localization_allow_author_localization` However, it missed out checking if the user can even see the model. This commit fixes that by adding the checks. This issue was found as I was adding a new model (`tags`) and discovered they were absent for the older models. This commit also introduces a small refactor that `.find`s the model first on the controller and passes the object, so that the subsequent services do not have to `.find` them again.
68 lines
2 KiB
Ruby
68 lines
2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class PostLocalizationsController < ApplicationController
|
|
before_action :ensure_logged_in
|
|
|
|
def show
|
|
post_id = params[:id] || params[:post_id]
|
|
raise ActionController::ParameterMissing.new(:id) if post_id.blank?
|
|
|
|
post = Post.find_by(id: post_id)
|
|
return render_json_error(I18n.t("not_found"), status: :not_found) if post.blank?
|
|
|
|
guardian.ensure_can_localize_post!(post)
|
|
|
|
post_localizations = PostLocalization.where(post_id: post.id)
|
|
|
|
topic_localizations_by_locale = {}
|
|
if post.is_first_post?
|
|
TopicLocalization
|
|
.where(topic_id: post.topic_id)
|
|
.each { |tl| topic_localizations_by_locale[tl.locale] = tl }
|
|
end
|
|
|
|
post_localizations.each do |pl|
|
|
pl.define_singleton_method(:topic_localization) { topic_localizations_by_locale[pl.locale] }
|
|
end
|
|
|
|
render json: {
|
|
post_localizations:
|
|
ActiveModel::ArraySerializer.new(
|
|
post_localizations,
|
|
each_serializer: PostLocalizationSerializer,
|
|
root: false,
|
|
).as_json,
|
|
},
|
|
status: :ok
|
|
end
|
|
|
|
def create_or_update
|
|
post_id, locale, raw = params.require(%i[post_id locale raw])
|
|
|
|
post = Post.find_by(id: post_id)
|
|
raise Discourse::NotFound unless post
|
|
|
|
guardian.ensure_can_localize_post!(post)
|
|
|
|
localization = PostLocalization.find_by(post_id: post.id, locale:)
|
|
if localization
|
|
PostLocalizationUpdater.update(post:, locale:, raw:, user: current_user)
|
|
render json: success_json, status: :ok
|
|
else
|
|
PostLocalizationCreator.create(post:, locale:, raw:, user: current_user)
|
|
render json: success_json, status: :created
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
post_id, locale = params.require(%i[post_id locale])
|
|
|
|
post = Post.find_by(id: post_id)
|
|
raise Discourse::NotFound unless post
|
|
|
|
guardian.ensure_can_localize_post!(post)
|
|
|
|
PostLocalizationDestroyer.destroy(post:, locale:, acting_user: current_user)
|
|
head :no_content
|
|
end
|
|
end
|