Comment a post
POSThttps://api.postpress.ai/v1/posts/{post_id}/comments
Comment a post or reply to a post comment.
Authorization
X-API-KEYstringrequired
API key from your postpress dashboard. Sent as a request header.
Path parameters
post_idstringrequired
The id of the post being commented on. LinkedIn: use the `social_id` from the post object (the id visible in the post URL won't work in every case). Instagram: use the `provider_id`; the shortcode is not accepted here.
Request body
Submit the request as multipart/form-data so binary attachments can be uploaded alongside text fields. Object/array fields (such as mentions) should be sent as JSON-encoded strings.
account_idstringrequiredThe id of the linked account to perform the request from.
textstringrequiredThe comment text. Min 1, max 1250 characters. LinkedIn: insert a mention with `{{index}}` referencing the `mentions` array (e.g. `Hey {{0}}, ...`). Instagram: mention a user with `@username`.
comment_idstringWhen set, the request posts a reply to this comment instead of a top-level comment. LinkedIn: use the comment id returned by the comments list.
attachmentsarray of files (binary)Media files to attach. LinkedIn accepts a single image, resolution limited to 6012x6012 px max.
mentionsarray of objectsLinkedIn only. Users referenced from `text` via `{{index}}` placeholders.
mentions object
namestringrequiredThe name of the user as it will be displayed in your comment.
profile_idstringrequiredThe provider id of the user. Begins with ACo/ADo for individuals and is a series of digits for companies.
is_companybooleanSet to true when mentioning a company page.
external_linkstringLinkedIn only. URL to render as a preview card. Must also appear in `text`; if not, it is appended at the end. Must match `^https?://`.
as_organizationstringLinkedIn only. The id of an organization you administer, to comment on its behalf.
Response 201 Created
Returned when the comment has been published successfully.
objectstringCommentSentrequiredcomment_idstringThe id of the newly created comment, when available from the provider.
Example request
curl --request POST \
--url 'https://api.postpress.ai/api/v1/posts/urn:li:activity:7332661864792854528/comments' \
--header 'X-API-KEY: pp_live_...' \
--header 'accept: application/json' \
--header 'content-type: multipart/form-data' \
--form 'account_id=acc_linkedin_01HXYZ4QK3WJ8FN3M6QH7TZ8GR' \
--form 'text=Great share!'Example response
{
"object": "CommentSent",
"comment_id": "7332661864792854528_7332661900000000001"
}Errors
Every error response follows the same envelope:
titlestringrequired
Short error title.
detailstringoptional
Human-readable explanation.
instancestringoptional
Request identifier for support.
typestringrequired
Error type identifier.
statusnumberrequired
HTTP status code.
401 Unauthorized13 types
Credentials are missing, expired, or otherwise invalid.
errors/missing_credentials- Some credentials are necessary to perform the request.errors/multiple_sessions- LinkedIn limits multiple sessions on certain Recruiter accounts. Use the cookie connection method.errors/wrong_account- The provided credentials do not match the correct account.errors/invalid_credentials- The provided credentials are invalid.errors/invalid_proxy_credentials- The provided proxy credentials are invalid.errors/invalid_checkpoint_solution- The checkpoint resolution did not pass successfully. Retry.errors/checkpoint_error- The checkpoint does not appear to be resolvable.errors/expired_credentials- Credentials have expired. Reconnect the account.errors/expired_link- This link has expired. Generate a new one.errors/insufficient_privileges- This resource is out of your API-key scopes.errors/disconnected_account- The account is disconnected from the provider service.errors/disconnected_feature- The service you're trying to reach is disconnected.errors/invalid_credentials_but_valid_account_imap- IMAP/SMTP credentials are invalid but the account is otherwise valid.
403 Forbidden9 types
Authenticated but the account is restricted or the action is not allowed.
errors/insufficient_permissions- Valid authentication but insufficient permissions to perform the request.errors/account_restricted- The account has been restricted by the provider.errors/account_mismatch- This action cannot be done with your account.errors/unknown_authentication_context- An additional step seems necessary to complete login.errors/session_mismatch- Token user id does not match client session id.errors/feature_not_subscribed- The requested feature has not been subscribed or authenticated properly.errors/subscription_required- A subscription is required to use this feature.errors/resource_access_restricted- You don't have access to this resource.errors/action_required- An additional step is required.
404 Not Found2 types
The post (or comment) targeted by the request does not exist.
errors/resource_not_found- The requested resource was not found.errors/invalid_resource_identifier- The provided identifier is not valid for this resource.
500 Internal Server Error3 types
Something went wrong on our side or with the upstream provider.
errors/unexpected_error- Something went wrong.errors/provider_error- The provider is experiencing operational problems. Retry later.errors/authentication_intent_error- The current authentication intent was killed after failure.
503 Service Unavailable5 types
postpress is temporarily unable to handle the request.
errors/no_client_session- No client session is currently running.errors/no_channel- No channel to client session.errors/no_handler- Handler missing for that request.errors/network_down- Network is down on the server side. Retry shortly.errors/service_unavailable- Service temporarily unavailable. Retry later.
504 Gateway Timeout1 types
The upstream provider did not respond in time.
errors/request_timeout- Request timed out. Retry, and contact support if it persists.
Updated May 2026