mirror of
https://github.com/discourse/discourse.git
synced 2024-11-26 19:33:39 +08:00
Current user serializer groups (ef7f84b
follow-up)
This commit is contained in:
parent
5c2e194d01
commit
98d09c90ac
|
@ -716,6 +716,16 @@ User.reopenClass(Singleton, {
|
||||||
// TODO: Use app.register and junk Singleton
|
// TODO: Use app.register and junk Singleton
|
||||||
createCurrent() {
|
createCurrent() {
|
||||||
const userJson = PreloadStore.get("currentUser");
|
const userJson = PreloadStore.get("currentUser");
|
||||||
|
|
||||||
|
if (userJson && userJson.primary_group_id) {
|
||||||
|
const primaryGroup = userJson.groups.find(
|
||||||
|
group => group.id === userJson.primary_group_id
|
||||||
|
);
|
||||||
|
if (primaryGroup) {
|
||||||
|
userJson.primary_group_name = primaryGroup.name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (userJson) {
|
if (userJson) {
|
||||||
const store = Discourse.__container__.lookup("service:store");
|
const store = Discourse.__container__.lookup("service:store");
|
||||||
return store.createRecord("user", userJson);
|
return store.createRecord("user", userJson);
|
||||||
|
|
|
@ -353,6 +353,10 @@ class User < ActiveRecord::Base
|
||||||
.maximum("groups.grant_trust_level")
|
.maximum("groups.grant_trust_level")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def visible_groups
|
||||||
|
groups.visible_groups(self)
|
||||||
|
end
|
||||||
|
|
||||||
def enqueue_welcome_message(message_type)
|
def enqueue_welcome_message(message_type)
|
||||||
return unless SiteSetting.send_welcome_message?
|
return unless SiteSetting.send_welcome_message?
|
||||||
Jobs.enqueue(:send_system_message, user_id: id, message_type: message_type)
|
Jobs.enqueue(:send_system_message, user_id: id, message_type: message_type)
|
||||||
|
|
|
@ -38,14 +38,16 @@ class CurrentUserSerializer < BasicUserSerializer
|
||||||
:previous_visit_at,
|
:previous_visit_at,
|
||||||
:seen_notification_id,
|
:seen_notification_id,
|
||||||
:primary_group_id,
|
:primary_group_id,
|
||||||
:primary_group_name,
|
|
||||||
:can_create_topic,
|
:can_create_topic,
|
||||||
:link_posting_access,
|
:link_posting_access,
|
||||||
:external_id,
|
:external_id,
|
||||||
:top_category_ids,
|
:top_category_ids,
|
||||||
:hide_profile_and_presence
|
:hide_profile_and_presence,
|
||||||
|
:groups
|
||||||
|
|
||||||
has_many :groups, embed: :object, serializer: BasicGroupSerializer
|
def groups
|
||||||
|
object.visible_groups.pluck(:id, :name).map { |id, name| { id: id, name: name.downcase } }
|
||||||
|
end
|
||||||
|
|
||||||
def link_posting_access
|
def link_posting_access
|
||||||
scope.link_posting_access
|
scope.link_posting_access
|
||||||
|
@ -210,14 +212,6 @@ class CurrentUserSerializer < BasicUserSerializer
|
||||||
object.primary_group_id.present?
|
object.primary_group_id.present?
|
||||||
end
|
end
|
||||||
|
|
||||||
def primary_group_name
|
|
||||||
object.primary_group.name.downcase
|
|
||||||
end
|
|
||||||
|
|
||||||
def include_primary_group_name?
|
|
||||||
object.primary_group&.name.present?
|
|
||||||
end
|
|
||||||
|
|
||||||
def external_id
|
def external_id
|
||||||
object&.single_sign_on_record&.external_id
|
object&.single_sign_on_record&.external_id
|
||||||
end
|
end
|
||||||
|
|
|
@ -65,4 +65,24 @@ RSpec.describe CurrentUserSerializer do
|
||||||
expect(payload[:top_category_ids]).to eq([category2.id, category1.id])
|
expect(payload[:top_category_ids]).to eq([category2.id, category1.id])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "#groups" do
|
||||||
|
let(:member) { Fabricate(:user) }
|
||||||
|
let :serializer do
|
||||||
|
CurrentUserSerializer.new(member, scope: Guardian.new, root: false)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should only show visible groups" do
|
||||||
|
Fabricate.build(:group, visibility_level: Group.visibility_levels[:public])
|
||||||
|
hidden_group = Fabricate.build(:group, visibility_level: Group.visibility_levels[:owners])
|
||||||
|
public_group = Fabricate.build(:group, visibility_level: Group.visibility_levels[:public])
|
||||||
|
hidden_group.add(member)
|
||||||
|
hidden_group.save!
|
||||||
|
public_group.add(member)
|
||||||
|
public_group.save!
|
||||||
|
payload = serializer.as_json
|
||||||
|
|
||||||
|
expect(payload[:groups]).to eq([{ id: public_group.id, name: public_group.name }])
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue
Block a user