Skip to content

Conversation

@darddan
Copy link

@darddan darddan commented Aug 31, 2025

Issue: #1360

I've built a bot that will poll my fider instance for new comments and in case there's an instruction for the but there it will do some processing and it will enrich the post. For that, in the current implementation I have to fetch all the comments from all the existing posts and filter what I've already processed.

This PR introduces a new endpoint GET /api/v1/comments with an optional query param since where you can pass a date to filter out comments created/edited before that date.

Data model:
In this endpoint I only return the comment_id, post_id, user_id, created_at and changed_at. Because of that I created a new model called CommentRef and didn't use the current Comment one.

Indexing:
I'm assuming the tenant_id is used for the hosted service that you provide, so I added an index for tenant_id, COALESCE(edited_at, created_at) to assure the performance stays decent.

Limit:
I didn't add a limit parameter to limit the comments in the response. Not only because I didn't actually need them in my instance, but I also noticed that they're not present in other api requests. This might lead to too much memory use or similar issues for larger platforms, so it might important for your hosted instance

@mattwoberts
Copy link
Contributor

Hey @darddan

Thanks for this.

Just on the limit - you're right to point out that it might be an issue for some instances. Not having a limit for the existing endpoint that lists comments for a post is I suppose OK - since you're unlikely to get that many for a single post. But if you're listing ALL comments from ALL posts, that's potentially a LOT of comments, so I would like to see a limit on there, with a default. Which means we'd need some sort of support for paging there too (I don't think any of the existing endpoints have this - listing posts has a limit with a default, but no "from" or similar)

So - I think we're going to need to add support for that really... What do you think?

@mattwoberts
Copy link
Contributor

@darddan I've added some paging logic - defaults to 50, you can go up to 100, so if you have more comments than 100, you'll need to check the pagination stuff - how does that look to you?

@mattwoberts
Copy link
Contributor

@darddan I'm not sure about the usefulness of just returning "CommentRefs" - that's obviously useful for your scenario but for others I think it's more sensible / useful to return the same comment info that we return when you get comments for a post

@darddan
Copy link
Author

darddan commented Sep 20, 2025

Hi @mattwoberts, appologies for the late response.

Regarding the 100 comments limit / pagination: The since param is there already, and I already use that to not get all the comments every time. I think that can be used for pagination, or at least for loading all the comments.

Regarding the CommentRefs: I couldn't think of any other use case for this endpoint unless if you're using it as a change stream for bots or something similar. I also thought that the more complex query would be harder to optimize, and would add more overhead. I can adapt it so that it gets all the comments instead if needed.

@mattwoberts
Copy link
Contributor

@darddan Did you see I added paging to this PR - could you take a look at that and see what you think, and if you think it would work with your use case still with these changes?

@darddan
Copy link
Author

darddan commented Oct 6, 2025

@mattwoberts looks great, thanks a lot. These changes would work for me

@mattwoberts
Copy link
Contributor

@darddan Sorry this one's been hanging around a while... I've got a couple of things stacking up for a release, I could perhaps bring this into that too....

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants