Hide member last names from non-vetted members

This commit is contained in:
Tanner Collin 2021-08-19 07:42:01 +00:00
parent c98efeff3a
commit aa5a01681f
3 changed files with 44 additions and 6 deletions

View File

@ -100,7 +100,29 @@ class TransactionSerializer(serializers.ModelSerializer):
# member viewing other members # member viewing other members
# hide info for non-vetted members so someone sitting
# in our parking lot can't scrape all our info
class OtherMemberSerializer(serializers.ModelSerializer): class OtherMemberSerializer(serializers.ModelSerializer):
last_name = serializers.SerializerMethodField()
class Meta:
model = models.Member
fields = [
'id',
'preferred_name',
'last_name',
'status',
'current_start_date',
'application_date',
'photo_small',
'public_bio',
]
def get_last_name(self, obj):
return obj.last_name[0] + '.'
# vetted member viewing other members
class VettedOtherMemberSerializer(serializers.ModelSerializer):
class Meta: class Meta:
model = models.Member model = models.Member
fields = [ fields = [
@ -234,13 +256,23 @@ class SearchSerializer(serializers.Serializer):
serializer = OtherMemberSerializer(obj) serializer = OtherMemberSerializer(obj)
return serializer.data return serializer.data
# vetted member viewing member list or search result
class VettedSearchSerializer(serializers.Serializer):
q = serializers.CharField(write_only=True, max_length=64)
seq = serializers.IntegerField(write_only=True)
member = serializers.SerializerMethodField()
def get_member(self, obj):
serializer = VettedOtherMemberSerializer(obj)
return serializer.data
# instructor viewing search result # instructor viewing search result
class InstructorSearchSerializer(serializers.Serializer): class InstructorSearchSerializer(serializers.Serializer):
member = serializers.SerializerMethodField() member = serializers.SerializerMethodField()
training = serializers.SerializerMethodField() training = serializers.SerializerMethodField()
def get_member(self, obj): def get_member(self, obj):
serializer = OtherMemberSerializer(obj) serializer = VettedOtherMemberSerializer(obj)
return serializer.data return serializer.data
def get_training(self, obj): def get_training(self, obj):
@ -402,7 +434,7 @@ class SessionSerializer(serializers.ModelSerializer):
def get_instructor_name(self, obj): def get_instructor_name(self, obj):
if obj.instructor and hasattr(obj.instructor, 'member'): if obj.instructor and hasattr(obj.instructor, 'member'):
name = '{} {}'.format(obj.instructor.member.preferred_name, obj.instructor.member.last_name[0]) name = '{} {}.'.format(obj.instructor.member.preferred_name, obj.instructor.member.last_name[0])
else: else:
name = 'Unknown' name = 'Unknown'
return obj.old_instructor or name return obj.old_instructor or name

View File

@ -54,6 +54,8 @@ class SearchViewSet(Base, Retrieve):
return serializers.AdminSearchSerializer return serializers.AdminSearchSerializer
elif self.request.user.member.is_instructor and self.action == 'retrieve': elif self.request.user.member.is_instructor and self.action == 'retrieve':
return serializers.InstructorSearchSerializer return serializers.InstructorSearchSerializer
elif self.request.user.member.vetted_date:
return serializers.VettedSearchSerializer
else: else:
return serializers.SearchSerializer return serializers.SearchSerializer
@ -126,7 +128,12 @@ class SearchViewSet(Base, Retrieve):
num_results = 100 num_results = 100
queryset = self.get_queryset()[:num_results] queryset = self.get_queryset()[:num_results]
if self.request.user.member.vetted_date:
serializer = serializers.VettedSearchSerializer(queryset, many=True)
else:
serializer = serializers.SearchSerializer(queryset, many=True) serializer = serializers.SearchSerializer(queryset, many=True)
return Response({'seq': seq, 'results': serializer.data}) return Response({'seq': seq, 'results': serializer.data})

View File

@ -73,8 +73,6 @@ export function Members(props) {
const [search, setSearch] = useState(searchDefault); const [search, setSearch] = useState(searchDefault);
const { token } = props; const { token } = props;
console.log(sort);
useEffect(() => { useEffect(() => {
setResponse(false); setResponse(false);
searchCache = search.q; searchCache = search.q;
@ -197,6 +195,7 @@ export function MemberDetail(props) {
}, [refreshCount]); }, [refreshCount]);
const member = result.member || false; const member = result.member || false;
const photo = member?.photo_large || member?.photo_small || false;
return ( return (
<Container> <Container>
@ -208,7 +207,7 @@ export function MemberDetail(props) {
<Grid stackable columns={2}> <Grid stackable columns={2}>
<Grid.Column width={isAdmin(user) ? 8 : 5}> <Grid.Column width={isAdmin(user) ? 8 : 5}>
<p> <p>
<Image rounded size='medium' src={member.photo_large ? staticUrl + '/' + member.photo_large : '/nophoto.png'} /> <Image rounded size='medium' src={photo ? staticUrl + '/' + photo : '/nophoto.png'} />
</p> </p>
{isAdmin(user) ? {isAdmin(user) ?