Пример #1
0
class ReviewResponsesSerializer(serializers.ModelSerializer):
    author = profile_serializers.ShortProfileSerializer()

    class Meta:
        model = models.Review
        fields = ('id', 'author', 'listing', 'rate', 'text', 'edited_date', 'created_date')
        validators = []  # Remove a default "unique together" constraint.
Пример #2
0
class ListingActivitySerializer(serializers.ModelSerializer):
    author = profile_serializers.ShortProfileSerializer()
    listing = ShortListingSerializer()
    change_details = ChangeDetailSerializer(many=True)

    class Meta:
        model = models.ListingActivity
        fields = ('action', 'activity_date', 'description', 'author',
                  'listing', 'change_details')
Пример #3
0
class NotificationMailBoxSerializer(serializers.HyperlinkedModelSerializer):
    created_date = serializers.DateTimeField(required=False, source='notification.created_date')
    expires_date = serializers.DateTimeField(required=False, source='notification.expires_date')
    author = profile_serializers.ShortProfileSerializer(required=False, source='notification.author')
    message = serializers.CharField(required=False, source='notification.message')
    listing = NotificationListingSerializer(required=False, source='notification.listing')
    agency = NotificationAgencySerializer(required=False, source='notification.agency')
    peer = DictField(required=False, source='notification.peer')
    notification_type = serializers.CharField(required=False, source='notification.notification_type')
    notification_subtype = serializers.CharField(required=False, source='notification.notification_subtype')
    entity_id = serializers.IntegerField(required=False, source='notification.entity_id')
    notification_id = serializers.IntegerField(required=False, source='notification.id')

    class Meta:
        model = models.NotificationMailBox
        fields = ('id', 'notification_id', 'created_date', 'expires_date', 'author',
            'message', 'notification_type', 'notification_subtype', 'listing', 'agency', 'entity_id', 'peer',
            'read_status', 'acknowledged_status', )
Пример #4
0
class SubscriptionSerializer(serializers.ModelSerializer):
    target_profile = profile_serializers.ShortProfileSerializer(required=False)

    class Meta:
        model = models.Subscription
        fields = (
            'id',
            'target_profile',
            'entity_type',
            'entity_id',
        )

    def to_representation(self, data):
        ret = super(SubscriptionSerializer, self).to_representation(data)

        try:
            if ret['entity_type'] == 'category':
                ret['entity_description'] = category_model_access.get_category_by_id(
                    ret['entity_id'], True).title
            elif ret['entity_type'] == 'tag':
                ret['entity_description'] = listing_model_access.get_tag_by_id(
                    ret['entity_id'], True).name
        except ObjectDoesNotExist:
            # Incase Category/Tag has been delete
            ret['entity_description'] = 'OBJECT NOT FOUND'

        return ret

    def validate(self, validated_data):
        """ Responsible of cleaning and validating user input data """
        validated_data['error'] = None
        # username = self.context['request'].user.username

        if 'entity_type' not in validated_data or 'entity_id' not in validated_data:
            raise serializers.ValidationError(
                'Subscriptions can only be one type.')

        entity_type = validated_data.get('entity_type')
        entity_id = validated_data.get('entity_id')
        if entity_type and entity_id:
            try:
                if entity_type == 'category':
                    validated_data[
                        'entity_id'] = category_model_access.get_category_by_id(
                            entity_id, True).id
                elif entity_type == 'tag':
                    validated_data[
                        'entity_id'] = listing_model_access.get_tag_by_id(
                            entity_id, True).id
                else:
                    raise serializers.ValidationError(
                        'entity_type is not valid')
            except ObjectDoesNotExist:
                raise serializers.ValidationError('Could not find object')
        else:
            raise serializers.ValidationError(
                'entity_type or entity_id missing')

        return validated_data

    def create(self, validated_data):
        """
        Used to create subscriptions
        """
        if validated_data['error']:
            raise serializers.ValidationError('{0}'.format(
                validated_data['error']))

        username = self.context['request'].user.username
        subscription = model_access.create_subscription(
            username, validated_data['entity_type'],
            validated_data.get('entity_id'))
        return subscription

    def update(self, instance, validated_data):
        """
        This is only used to update the expired_date field (effectively
        deleting a subscription while still leaving a record of it)
        """
        if validated_data['error']:
            raise serializers.ValidationError('{0}'.format(
                validated_data['error']))

        try:
            username = self.context['request'].user.username
            subscription = model_access.update_subscription(
                username, instance, validated_data['entity_type'],
                validated_data['entity_id'])
        except Exception as err:
            raise serializers.ValidationError('{0}'.format(err))
        return subscription
Пример #5
0
class NotificationSerializer(serializers.HyperlinkedModelSerializer):
    author = profile_serializers.ShortProfileSerializer(required=False)
    listing = NotificationListingSerializer(required=False)
    agency = NotificationAgencySerializer(required=False)

    class Meta:
        model = models.Notification
        fields = (
            'id',
            'created_date',
            'expires_date',
            'author',
            'message',
            'notification_type',
            'listing',
            'agency',
            'entity_id',
            'peer',
        )

        extra_kwargs = {
            'listing': {
                'validators': []
            },
            'agency': {
                'validators': []
            },
        }

    def to_representation(self, data):
        access_control_instance = plugin_manager.get_system_access_control_plugin(
        )
        ret = super(NotificationSerializer, self).to_representation(data)

        peer = ret['peer']
        if peer and peer.get('_bookmark_listing_ids'):
            del peer['_bookmark_listing_ids']
        # Used to anonymize usernames
        anonymize_identifiable_data = system_anonymize_identifiable_data(
            self.context['request'].user.username)

        if anonymize_identifiable_data:
            if peer:
                peer['user'][
                    'username'] = access_control_instance.anonymize_value(
                        'username')
            # TODO: Hide Peer data (erivera 2016-07-29)

        # del ret['agency']
        # del ret['listing']
        return ret

    def validate(self, validated_data):
        """ Responsible of cleaning and validating user input data """
        validated_data['error'] = None
        initial_data = self.initial_data
        username = self.context['request'].user.username

        # Check for notification types
        key_type_list = []

        if 'listing' in initial_data:
            key_type_list.append('listing')

        if 'agency' in initial_data:
            key_type_list.append('agency')

        if 'peer' in initial_data:
            key_type_list.append('peer')

        if len(key_type_list) >= 2:
            raise serializers.ValidationError(
                'Notifications can only be one type. Input: {0}'.format(
                    key_type_list))

        if 'message' not in validated_data and self.context[
                'request'].method == 'POST':
            raise serializers.ValidationError(
                'Messsage field is required for POST Request')

        # TODO: Figure how to get listing data using validated data
        listing = initial_data.get('listing')
        if listing:
            if listing.get('id'):
                try:
                    validated_data[
                        'listing'] = listing_model_access.get_listing_by_id(
                            username, initial_data['listing']['id'], True)
                except ObjectDoesNotExist:
                    raise serializers.ValidationError('Could not find listing')
            else:
                raise serializers.ValidationError(
                    'Valid Listing ID is required')
        else:
            validated_data['listing'] = None

        # Agency Validation
        agency = initial_data.get('agency')
        if agency:
            if agency.get('id'):
                try:
                    validated_data[
                        'agency'] = agency_model_access.get_agency_by_id(
                            initial_data['agency']['id'], True)
                except ObjectDoesNotExist:
                    raise serializers.ValidationError('Could not find agency')
            else:
                raise serializers.ValidationError(
                    'Valid Agency ID is required')
        else:
            validated_data['agency'] = None

        # Peer Validation
        peer = initial_data.get('peer')
        if peer:
            temp_peer = {}

            if peer.get('user'):
                temp_peer['user'] = peer.get('user')

            if peer.get('folder_name'):
                temp_peer['folder_name'] = peer.get('folder_name')

            target_username = temp_peer.get('user', {}).get('username')

            if not target_username:
                raise serializers.ValidationError('Valid Username is Required')

            target_username_profile = generic_model_access.get_profile(
                target_username)

            if not target_username_profile:
                raise serializers.ValidationError('Valid User is Required')

            validated_data['entity_target'] = target_username_profile
            validated_data['entity_id'] = target_username_profile.pk
            # Folder Validation - Optional Field
            temp_folder_name = temp_peer.get('folder_name')
            if temp_folder_name:
                library_query = library_model_access.get_self_application_library(
                    username, folder_name=temp_folder_name)
                temp_peer['_bookmark_listing_ids'] = [
                    library_query_entry.listing.id
                    for library_query_entry in library_query
                ]

                # temp_peer['_user_folders'] = library_serializers.UserLibrarySerializer(library_query,
                #      many=True, context={'request': self.context['request']}).data

                if len(temp_peer['_bookmark_listing_ids']) == 0:
                    raise serializers.ValidationError(
                        'No entries in target folder')

            validated_data['peer'] = temp_peer
        else:
            validated_data['peer'] = None

        return validated_data

    def create(self, validated_data):
        """
        Used to create notifications
        """
        if validated_data['error']:
            raise serializers.ValidationError('{0}'.format(
                validated_data['error']))

        username = self.context['request'].user.username
        notification = model_access.create_notification(
            author_username=username,
            expires_date=validated_data['expires_date'],
            message=validated_data['message'],
            listing=validated_data['listing'],
            agency=validated_data['agency'],
            peer=validated_data['peer'],
            peer_profile=validated_data.get('entity_target'))
        return notification

    def update(self, instance, validated_data):
        """
        This is only used to update the expired_date field (effectively
        deleting a notification while still leaving a record of it)
        """
        if validated_data['error']:
            raise serializers.ValidationError('{0}'.format(
                validated_data['error']))

        username = self.context['request'].user.username
        notification = model_access.update_notification(
            username, instance, validated_data['expires_date'])
        return notification
Пример #6
0
class RejectionListingActivitySerializer(serializers.ModelSerializer):
    author = profile_serializers.ShortProfileSerializer()

    class Meta:
        model = models.ListingActivity
        fields = ('action', 'activity_date', 'description', 'author')
Пример #7
0
class ReviewSerializer(serializers.ModelSerializer):
    author = profile_serializers.ShortProfileSerializer()

    class Meta:
        model = models.Review
        fields = ('author', 'listing', 'rate', 'text', 'edited_date', 'id')
Пример #8
0
class ReviewSerializer(serializers.ModelSerializer):
    author = profile_serializers.ShortProfileSerializer()
    review_responses = ReviewResponsesField()

    class Meta:
        model = models.Review
        fields = ('id', 'author', 'listing', 'rate', 'text', 'edited_date', 'created_date', 'review_parent', 'review_responses')
        validators = []  # Remove a default "unique together" constraint.

    def to_representation(self, data):
        data = super(ReviewSerializer, self).to_representation(data)

        responses_queryset = models.Review.objects.for_user(self.context['request'].user.username).filter(review_parent=data['id']).order_by('created_date')
        review_responses_serializer = ReviewResponsesSerializer(responses_queryset, context={'request': self.context['request']}, many=True)
        data['review_responses'] = review_responses_serializer.data

        return data

    def validate(self, data):
        """
        validate review
        """
        data['listing'] = self.context['listing']

        if 'rate' not in data:
            raise serializers.ValidationError('Missing required rate field')

        if 'text' not in data:
            data['text'] = None
            # raise serializers.ValidationError('Missing required text field')

        if 'review_parent' not in data:
            data['review_parent'] = None
        else:
            review_parent = data['review_parent']

            if review_parent.review_parent is not None:
                raise serializers.ValidationError('More than one level review responses not allowed')

        return data

    def create(self, validated_data):
        profile = generic_model_access.get_profile(self.context['request'].user.username)
        try:
            resp = model_access.create_listing_review(profile,
                        validated_data['listing'],
                validated_data['rate'],
                validated_data['text'],
                validated_data['review_parent'])
        except ValidationError as err:
            raise serializers.ValidationError('{}'.format(err))
        return resp

    def update(self, review_instance, validated_data):
        try:
            review = model_access.edit_listing_review(self.context['request'].user.username,
                                                      review_instance,
                                                      validated_data['rate'],
                                                      validated_data['text'])
        except ValidationError as err:
            raise serializers.ValidationError('{}'.format(err))
        return review