- HTTP request
- Request body
- Response body
- RemittanceStatementDetailsResponse
- IssuerSummary
- RevshareCategorySummary
- RevshareCategory
- Event
- EventDetail
- EventSummary
- AdjustmentEvent
Returns transaction detail information about a remittance statement.
This is a paginated API. The number of transaction events per page can be specified with numberOfEvents
. If unspecified, the maximum of 1000 events will be returned per page. Each request to this API will return a nextEventOffset
pointing to the next transaction event in the statement, as well as remittanceStatementSummary.totalEvents
specifying the total number of transactions in the statement. If the current retrieved page contains the last transactions of the statement, nextEventOffset
will not be present in the response.
The statementId
value is the requestId
from the remittanceStatementNotificationRequest
If the endpoint encounters an error while processing the request, the response from this endpoint will be of type ErrorResponse
.
Responses to this query may be empty if this method does not return an HTTP 200. The response body is empty in situations where an ErrorResponse
with a clear description could be used to help an attacker understand the payment integrator account identifier of other integrators. In these situations, where either the signing key doesn't match, the payment integrator identifier was not found, or the encryption key was unknown, this method will return an HTTP 404 with an empty body. If the request signature could be verified, additional information regarding the error will be returned in the response body.
An example request looks like:
{
"requestHeader": {
"protocolVersion": {
"major": 1
},
"requestId": "statement_detail_request_139932019",
"requestTimestamp": {
"epochMillis": "1502551332087"
},
"paymentIntegratorAccountId": "InvisiCashUSA_USD"
},
"statementId": "0123434-statement-abc",
"numberOfEvents": 5
}
An example response looks like:
{
"responseHeader": {
"responseTimestamp": {
"epochMillis": "1481900013178"
}
},
"eventOffset": 0,
"nextEventOffset": 5,
"remittanceStatementSummary": {
"statementDate": {
"epochMillis": "1502521200000"
},
"billingPeriod": {
"startDate": {
"epochMillis": "1502434800000"
},
"endDate": {
"epochMillis": "1502434800000"
}
},
"dateDue": {
"epochMillis": "1502348400000"
},
"totalDueByIntegrator": {
"amountMicros": "1569000000",
"currencyCode": "INR"
},
"totalProcessedAmount": {
"amountMicros": "1669000000",
"currencyCode": "INR"
},
"totalFeesAmount": {
"amountMicros": "100000000",
"currencyCode": "INR"
},
"totalDirectTaxAmount": {
"amountMicros": "100000",
"currencyCode": "INR"
},
"totalWithholdingTaxAmount": {
"amountMicros": "-1000000",
"currencyCode": "INR"
},
"totalEvents": 15
},
"issuerSummaries": [
{
"issuerId": {
"value": "invisiCarrier"
},
"totalByIssuer": {
"amountMicros": "1569000000",
"currencyCode": "INR"
},
"captureSummaries": [
{
"revshareCategory": "APP",
"totalCharges": {
"amountMicros": "700000000",
"currencyCode": "INR"
},
"totalItemPrice": {
"amountMicros": "665000000",
"currencyCode": "INR"
},
"totalFees": {
"amountMicros": "-28000000",
"currencyCode": "INR"
},
"totalDirectTaxes": {
"amountMicros": "35000000",
"currencyCode": "INR"
},
"totalWithholdingTaxes": {
"amountMicros": "0",
"currencyCode": "INR"
}
},
{
"revshareCategory": "CONTENT",
"totalCharges": {
"amountMicros": "800000000",
"currencyCode": "INR"
},
"totalItemPrice": {
"amountMicros": "760000000",
"currencyCode": "INR"
},
"totalFees": {
"amountMicros": "-32000000",
"currencyCode": "INR"
},
"totalDirectTaxes": {
"amountMicros": "40000000",
"currencyCode": "INR"
},
"totalWithholdingTaxes": {
"amountMicros": "0",
"currencyCode": "INR"
}
},
{
"revshareCategory": "SPECIAL_APP",
"totalCharges": {
"amountMicros": "500000000",
"currencyCode": "INR"
},
"totalItemPrice": {
"amountMicros": "475000000",
"currencyCode": "INR"
},
"totalFees": {
"amountMicros": "-35000000",
"currencyCode": "INR"
},
"totalDirectTaxes": {
"amountMicros": "25000000",
"currencyCode": "INR"
},
"totalWithholdingTaxes": {
"amountMicros": "0",
"currencyCode": "INR"
}
}
],
"refundSummaries": [
{
"revshareCategory": "APP",
"totalCharges": {
"amountMicros": "-200000000",
"currencyCode": "INR"
},
"totalItemPrice": {
"amountMicros": "-190000000",
"currencyCode": "INR"
},
"totalFees": {
"amountMicros": "8000000",
"currencyCode": "INR"
},
"totalDirectTaxes": {
"amountMicros": "-10000000",
"currencyCode": "INR"
},
"totalWithholdingTaxes": {
"amountMicros": "0",
"currencyCode": "INR"
}
},
{
"revshareCategory": "CONTENT",
"totalCharges": {
"amountMicros": "-150000000",
"currencyCode": "INR"
},
"totalItemPrice": {
"amountMicros": "-142500000",
"currencyCode": "INR"
},
"totalFees": {
"amountMicros": "6000000",
"currencyCode": "INR"
},
"totalDirectTaxes": {
"amountMicros": "-7500000",
"currencyCode": "INR"
},
"totalWithholdingTaxes": {
"amountMicros": "0",
"currencyCode": "INR"
}
}
]
}
],
"captureEvents": [
{
"eventRequestId": "bWVyY2hhbnQgdHJhbnNhY3Rpb24gaWQ",
"revshareCategory": "APP",
"issuerId": {
"value": "invisiCarrier"
},
"eventDetail": {
"eventCharge": {
"amountMicros": "700000000",
"currencyCode": "INR"
},
"eventTax": {
"amountMicros": "35000000",
"currencyCode": "INR"
},
"eventFee": {
"amountMicros": "-28000000",
"currencyCode": "INR"
},
"presentmentChargeAmount": {
"amountMicros": "700000000",
"currencyCode": "INR"
},
"nanoExchangeRate": "10000000000000"
}
},
{
"eventRequestId": "Ggghvh78200PQ3Yrpb",
"revshareCategory": "CONTENT",
"issuerId": {
"value": "invisiCarrier"
},
"eventDetail": {
"eventCharge": {
"amountMicros": "800000000",
"currencyCode": "INR"
},
"eventTax": {
"amountMicros": "40000000",
"currencyCode": "INR"
},
"eventFee": {
"amountMicros": "-32000000",
"currencyCode": "INR"
},
"presentmentChargeAmount": {
"amountMicros": "800000000",
"currencyCode": "INR"
},
"nanoExchangeRate": "10000000000000"
}
},
{
"eventRequestId": "bWVyY2hhbnQgdHJhbnNhY3Rpb24gaWQ",
"revshareCategory": "SPECIAL_APP",
"issuerId": {
"value": "invisiCarrier"
},
"eventSummary": {
"eventCharge": {
"amountMicros": "500000000",
"currencyCode": "INR"
},
"eventTax": {
"amountMicros": "25000000",
"currencyCode": "INR"
},
"presentmentChargeAmount": {
"amountMicros": "500000000",
"currencyCode": "INR"
},
"nanoExchangeRate": "10000000000000"
}
}
],
"refundEvents": [
{
"eventRequestId": "liUrreQY233839dfFFb24gaQM",
"revshareCategory": "APP",
"issuerId": {
"value": "invisiCarrier"
},
"eventDetail": {
"eventCharge": {
"amountMicros": "-200000000",
"currencyCode": "INR"
},
"eventTax": {
"amountMicros": "-10000000",
"currencyCode": "INR"
},
"eventFee": {
"amountMicros": "8000000",
"currencyCode": "INR"
},
"presentmentChargeAmount": {
"amountMicros": "-200000000",
"currencyCode": "INR"
},
"nanoExchangeRate": "10000000000000"
}
},
{
"eventRequestId": "IIghhhUrreQY233839II9qM==",
"revshareCategory": "CONTENT",
"issuerId": {
"value": "invisiCarrier"
},
"eventDetail": {
"eventCharge": {
"amountMicros": "-150000000",
"currencyCode": "INR"
},
"eventTax": {
"amountMicros": "-7500000",
"currencyCode": "INR"
},
"eventFee": {
"amountMicros": "6000000",
"currencyCode": "INR"
},
"presentmentChargeAmount": {
"amountMicros": "-150000000",
"currencyCode": "INR"
},
"nanoExchangeRate": "10000000000000"
}
}
]
}
HTTP request
POST https://vgw.googleapis.com/gsp/carriers-v1/remittanceStatementDetails/:PIAID
Request body
The request body contains data with the following structure:
JSON representation |
---|
{ "requestHeader": { object (RequestHeader) }, "statementId": string, "eventOffset": integer, "numberOfEvents": integer } |
Fields | |
---|---|
requestHeader |
REQUIRED: Common header for all requests. |
statementId |
REQUIRED: Request ID of the statement notification. |
eventOffset |
OPTIONAL: Return events starting at this offset. This should be set to the |
numberOfEvents |
OPTIONAL: Number of events to show per page. If unspecified or greater than 1000, this will be 1000. |
Response body
This method supports multiple return types. For additional information about what 4XX or 5XX HTTP status code to return with an ErrorResponse
, consult the ErrorResponse
object and HTTP status codes documentation.
Possible response messages | |
---|---|
HTTP 200 Status |
|
HTTP 4XX / 5XX Status |
|
RemittanceStatementDetailsResponse
Response object for the remittance statement detail method.
JSON representation |
---|
{ "responseHeader": { object (ResponseHeader) }, "eventOffset": integer, "nextEventOffset": integer, "remittanceStatementSummary": { object (RemittanceStatementSummary) }, "issuerSummaries": [ { object ( |
Fields | |
---|---|
responseHeader |
REQUIRED: Common header for all responses. |
eventOffset |
REQUIRED: The event offset of this response. |
nextEventOffset |
OPTIONAL: The offset of the next event to return. If unspecified there are no more events to retrieve for this statement. |
remittanceStatementSummary |
REQUIRED: Summary of this remittance statement. |
issuerSummaries[] |
REQUIRED: Summaries of the events in this statement, categorized by issuer. |
captureEvents[] |
REQUIRED: Set of capture events. |
refundEvents[] |
REQUIRED: Set of refund events. |
adjustmentEvents[] |
OPTIONAL: Set of adjustment events. Adjustment events may be added at Google's discretion to reconcile billing discrepancies, for example if fees were undercomputed for a set of prior transactions, an adjustment may be used to make the integrator whole. |
IssuerSummary
JSON representation |
---|
{ "issuerId": { object (IssuerId) }, "totalByIssuer": { object (Amount) }, "captureSummaries": [ { object ( |
Fields | |
---|---|
issuerId |
REQUIRED: The issuer this summary applies to. |
totalByIssuer |
REQUIRED: The invoiced amount attributed to this issuer in this statement. This value is provided for information only, it should not be remitted separately. Instead the totalDueByIntegrator found in the RemittanceStatementSummary should be remitted. |
captureSummaries[] |
OPTIONAL: Summaries of all capture events that occurred during this statement period, classified by RevshareCategory. |
refundSummaries[] |
OPTIONAL: Summaries of all refund events that occurred during this statement period, classified by RevshareCategory. |
Event
Structure representing a single event included in a remittance statement.
JSON representation |
---|
{ "eventRequestId": string, "revshareCategory": enum ( |
Fields | |
---|---|
eventRequestId |
REQUIRED: For capture or refund events, this will be the |
revshareCategory |
REQUIRED: The revshare category applied to this Event. |
issuerId |
REQUIRED: The issuer this event applies to. |
Union field event_info . Summary or detailed information about this Event. event_info can be only one of the following: |
|
eventDetail |
Detailed information about this event, including fees |
eventSummary |
Information about this event, excluding fees |
EventDetail
JSON representation |
---|
{ "eventCharge": { object (Amount) }, "eventTax": { object (Amount) }, "eventFee": { object (Amount) }, "presentmentChargeAmount": { object (Amount) }, "nanoExchangeRate": string } |
Fields | |
---|---|
eventCharge |
REQUIRED: If this value is negative then this represents monetary value moving from Google to the payment integrator. If this is positive it is money from the payment integrator due to Google. For example, capture transactions will always be positive, and refund transactions will always be negative. |
eventTax |
REQUIRED: If this value is negative then this represents monetary value moving from Google to the payment integrator. If this is positive it is money from the payment integrator due to Google. This value is the tax applied directly to this event, e.g. sales tax. |
eventFee |
REQUIRED: If this value is negative then this represents monetary value moving from Google to the payment integrator. If this is positive it is money from the payment integrator due to Google. For example, if an agreement says that Google will pay 1% of the |
presentmentChargeAmount |
REQUIRED: Transaction amount in the presentment (aka transaction) currency prior to foreign exchange. This field follows the same sign convention as the |
nanoExchangeRate |
REQUIRED: The exchange rate used in converting the presentment amount to the settlement (invoice) amount. This value is in nano basis points (1 basis point = .0001 = .01%). That is, to get the exchange rate, divide this field by 10^13. |
EventSummary
JSON representation |
---|
{ "eventCharge": { object (Amount) }, "eventTax": { object (Amount) }, "presentmentChargeAmount": { object (Amount) }, "nanoExchangeRate": string } |
Fields | |
---|---|
eventCharge |
REQUIRED: If this value is negative then this represents monetary value moving from Google to the payment integrator. If this is positive it is money from the payment integrator due to Google. For example, capture transactions will always be positive, and refund transactions will always be negative. |
eventTax |
REQUIRED: If this value is negative then this represents monetary value moving from Google to the payment integrator. If this is positive it is money from the payment integrator due to Google. This value is the tax applied directly to this event, e.g. sales tax. |
presentmentChargeAmount |
REQUIRED: Transaction amount in the presentment (aka transaction) currency prior to foreign exchange. This field follows the same sign convention as the |
nanoExchangeRate |
REQUIRED: The exchange rate used in converting the presentment amount to the settlement (invoice) amount. This value is in nano basis points (1 basis point = .0001 = .01%). That is, to get the exchange rate, divide this field by 10^13. |
AdjustmentEvent
JSON representation |
---|
{ "adjustmentId": string, "adjustmentAmount": { object (Amount) } } |
Fields | |
---|---|
adjustmentId |
REQUIRED: A unique ID assigned by Google to this adjustment event. |
adjustmentAmount |
REQUIRED: If this value is negative then this represents monetary value moving from Google to the payment integrator. If this is positive it is money from the payment integrator due to Google. |