Skip to main content

Get Push Logs

The IM service can provide push history records under the App Key. Push history records are provided in the form of log files and are compressed. You can use the server API to obtain the push logs for a specified app.

The server API interface only returns the download URL of the push log file. After obtaining the URL, please download it yourself.

Enable the Service

If needed, please submit a ticket to apply for enabling the Push Log Download Service.

Pricing Rules: "Push Log Download" is a value-added service. The IM Ultimate Plan allows free use of this service. Other IM pricing plans are charged based on the number of push logs generated by the server, in increments of 10 million logs. The cost is 150 RMB per 10 million logs for domestic data centers and 300 RMB per 10 million logs for international data centers. If the monthly push log count does not reach 10 million, the minimum charge applies. For specific details, refer to the Pricing Guide.

Push Log Description

tip

If your app uses an international data center, please complete the necessary configurations based on your SDK version to ensure that push-related statistics are reported to the correct data center. For more details, refer to the International Data Center Usage Guide.

Push logs currently support statistics for offline push notifications of one-to-one chats, group chats, and system conversations, as well as pushes sent via the /push.json and /push/user.json server APIs. The offline push log records for ultra groups are not yet complete and are not recommended for use.

Push Delivery Log Collection Notes

  • For Huawei and Meizu devices, the data collection for push delivery rates relies on the "Delivery Receipt" feature provided by Huawei and Meizu. You need to complete the corresponding configurations on the manufacturers' platforms. A brief guide is provided in the developer documentation:
  • The delivery rate statistics for Google FCM pushes only support the data message method and do not support the notification message method. Additionally, log data collection relies on active reporting by the application. For more details, refer to the Android client SDK documentation Collect FCM Push Delivery Data.
  • The delivery rate statistics for Apple APNs pushes rely on active reporting by the application. For more details, refer to the iOS client SDK documentation Report Push Data.

Push Click Log Collection Notes

  • The click rate statistics for Huawei pushes may rely on active reporting by the application, depending on the client SDK version:
    • SDK < 5.1.4: Does not support push click statistics.
    • 5.1.4 ≦ SDK < 5.2.3: Relies on active reporting by the application. See the Android client SDK documentation Collect Huawei Push Click Data.
    • SDK ≧ 5.2.3: The SDK automatically reports clicks, no application handling is required.
  • The click rate statistics for Apple APNs pushes rely on active reporting by the application. For more details, refer to the iOS client SDK documentation Report Push Data.

Data Timeliness

There is a certain delay in obtaining data (T+0 mode).

  • First, the data file for each natural hour is generated only after the hour ends. For example, the log data for the period between 12:00 and 13:00 is generated after 13:00.
  • Second, due to the time required for data statistics and file compression, it generally takes an additional 3 hours before the download URL is available. For example, the log data for the period between 12:00 and 13:00 will be available for download after 16:00.
  • Additionally, once the service is enabled, the server can save the push log data for the current natural hour. For example, if you enable the service at any time between 12:00 and 13:00, the IM server can provide push logs starting from 12:00.

The IM server packages push log data by natural hour, so push log data packages are only available on an hourly basis.

Log Retention Period

Push log files stored on the server are retained for only 7 days. After 7 days, the server automatically deletes these log files.

Log Format

NameTypeDescription
messageIdStringPush message ID.
receiverIdStringReceiver user ID.
systemTypeStringReceiver's device operating system type: iOS, Android
pushStatusStringPush status, which can be success (0), failure (1), delivered (2), or clicked (3).
sendTimeStringMessage send time, accurate to milliseconds, in UTC time for international data centers.
timeStringTimestamp of push status change, which may be the time of push success, failure, delivery, or click, depending on the pushStatus value. Accurate to milliseconds, in UTC time for international data centers.
pushTypeStringPush type. Possible values include MI, HW, HONOR, MEIZU, OPPO, VIVO, FCM, APNS, RONG (IM self-built push).
pushChannelIdStringChannel ID, only valid when pushStatus is success (0). Currently supported for Xiaomi, Huawei, and OPPO.
pIdStringPush correlation ID, only supported for FCM and APNS. Can be used to correlate push success, delivery, and click records to track push status changes for FCM and APNs. This field requires client SDK version ≧ 5.1.7.
requestIdStringPush request ID, which is the unique identifier for the IM server's API call to third-party push services. Can be used with pushToken to correlate push success, delivery, and click records for Xiaomi, Meizu, Huawei, VIVO, and OPPO.
pushTokenStringPush Token. Can be used with requestId to correlate push success, delivery, and click records for Xiaomi, Meizu, Huawei, VIVO, and OPPO.
deviceIdStringTarget device ID for the push. Can be used with messageId to correlate push success and click records for Huawei, VIVO, and OPPO.
senderIdStringMessage sender ID. If the push is sent directly (not triggered by a message), there is no message sender ID.
channelTypeStringThe type of conversation the message belongs to, which can be one-to-one chat (1), group chat (3), system notification (6), or ultra group chat (10).
channelIdStringThis field is deprecated. Currently, this field is only used for compatibility with older versions and is not recommended. Use targetId as a replacement.
targetIdStringConversation ID. Depending on the channelType value, this may be a group chat ID or ultra group ID. If channelType is a system conversation or one-to-one chat, this field is empty because the conversation ID is the receiver's user ID (receiverId).
groupChannelIdStringChannel ID in the ultra group scenario. This field is empty in non-ultra group scenarios.
thirdRespBodyString(Third-party platform return field) Push status callback from third-party push platforms, relying on the push receipt services provided by each manufacturer. Due to limitations of third-party platforms, callback data varies: Xiaomi and Meizu callbacks include push delivery and click data. Huawei, VIVO, and OPPO include push delivery data. In Huawei push callback data, if the push is triggered by the IM service, the bitag parameter value will have an rc prefix, structured as rc_{appkey}_{messageid}_0, e.g., rc_fafweefwf_596E-P5PG-4FS2-7OJK_0.
pushErrorCodeStringError code for push failures when the IM service sends pushes to third-party vendors.
pushErrorMsgStringPush failure description corresponding to the pushErrorCode.
thirdApiRespInfoString(Third-party platform return field) Response returned by the third-party push API. Refer to the third-party push platform documentation below the table.
thirdApiHttpStatusCodeString(Third-party platform return field) HTTP Status Code returned by the third-party push API. Refer to the third-party push platform documentation below the table.
thirdApiBusCodeString(Third-party platform return field) Business Code returned by the third-party push API. Refer to the third-party push platform documentation below the table.

Third-party push platform official documentation:

Request Method

POST: https://Data Center Domain/message/push/detail/history.json

Rate Limit: 100 requests per second

Signature Rule: All server API requests must be verified. For details, refer to API Request Signature.

Body Parameters

The HTTP request body data format is application/x-www-form-urlencoded, and the following HTTP form parameters are supported:

ParameterTypeRequiredDescription
dateStringYesSpecified time in the format YYYYMMDDHH, used to obtain push log data for a specific hour. For example, for an app using the China (Beijing) data center, to obtain data for the period between 1:00 AM and 2:00 AM on January 1, 2023, pass 2023010101. Note: If your app uses the Singapore data center, the date value should use Beijing time.

Request Example

POST /message/push/detail/history.json HTTP/1.1
Host: api-cn.ronghub.com
App-Key: uwd1c0sxdlx2
Timestamp: 1408710653491
Nonce: 14314
Signature: 45beb7cc7307889a8e711219a47b7cf6a5b000e8
Content-Type: application/x-www-form-urlencoded

date=2023010101

Response Parameters

Return ValueReturn TypeDescription
codeIntReturn code, 200 indicates success.
urlStringDownload URL for the historical records. If there is no message record data, the url value is empty.
dateStringHistorical record time.

Response Example

HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8

{
"code":200,
"url":"http://xx.com/1/c6720eea-452b-4f93-8159-7af3046611f1.gz",
"date":"2023010101"
}