1. Overview
There are two ways for companies to submit reports of apparent child sexual exploitation to NCMEC: they can submit a report using a web form or using this web service API, which allows a more automated reporting experience.
While ESPs have a statutory duty to report apparent child pornography to NCMEC’s CyberTipline (see 18 U.S.C. § 2258A), the reporting of data via the web service, other than the incident type and date/time of incident, is voluntary and undertaken at the ESPs' initiative.
2. Access
For production reporting, the API base URI is https://report.cybertip.org/ispws.
For testing, NCMEC provides a testing environment with base URI https://exttest.cybertip.org/ispws.
This documentation uses https://{applicationRoot}
as a representative base URI, which should be replaced with the appropriate production or testing environment URI from above.
All CyberTipline Reporting API endpoints use either GET
or POST
requests.
Endpoints are only accessible via HTTPS and authentication is required.
A username and password must be requested from and supplied by NCMEC.
Credentials appearing in this document are for the purpose of example only. You will not be able to use them to authenticate in either the testing or production environments. |
3. Endpoints
NCMEC’s Cybertip Reporting API is RESTful and provides the endpoints listed below, relative to one of the base URIs indicated above.
For example, to submit a report, a reporter would construct a POST
request to the URI https://{applicationRoot}/submit
.
A detailed report submission example is provided in a later section.
- GET
/status
-
Verify that the client can connect to and authenticate with the server.
- GET
/xsd
-
Download the latest XML schema definition.
- POST
/submit
-
Open a report submission. This is the first endpoint used to initiate the submission of a report. Requests to this endpoint require a body containing a single XML document conforming to the report schema. A response from the server will indicate whether the report was accepted and, if so, the ID assigned to the report. Only one XML document may be submitted per request.
- POST
/upload
-
Upload a file to a report. A successful request to begin a report submission must have been made prior to a request to this endpoint. Requests to this endpoint require the report ID to which the uploaded file is to be associated. A response from the server will indicate whether the file upload was successful and, if so, the ID assigned to the file. File uploads are optional and may be made as many times as necessary for the report. There is no limit to the size of uploaded files.
- POST
/fileinfo
-
Supply additional details for an uploaded file. A successful file upload must have been made prior to a request to this endpoint. Requests to this endpoint require a single XML document containing the report ID and file ID to which the file details are to be associated. A response from the server will indicate whether the file details submission was successful. File details submissions are optional and may be made once per uploaded file.
- POST
/finish
-
Finish a report submission. A report must be finished after all report contents have been uploaded for successful submission. A response from the server will indicate whether the request to finish the report was successful and, if so, the report ID and a list of file IDs associated with the report. Once a report is finished, additional files or file details cannot be added and the report cannot be cancelled. If a report is not finished by the reporter, the report is automatically deleted by NCMEC 24 hours after the date the report was opened or 1 hour after the last modification (file upload or file details submission), whichever is later.
- POST
/retract
-
Cancel a report submission. A report may be cancelled by a reporter before the report has been finished or it has been automatically cancelled by NCMEC after timing out. A response from the server will indicate whether the request to cancel the report was successful.
4. XML Root Elements
Below are the root elements defined by the CyberTipline Reporting API schema.
<report>
-
The root element used to submit a report.
<fileDetails>
-
The root element used to upload additional details about an uploaded file.
<reportResponse>
-
The root element of responses to
/submit
,/upload
,/fileinfo
, and/retract
requests. <reportDoneResponse>
-
The root element of the response to a
/finish
request.
5. Example Report Transactions
Below are example sequence diagrams for various report transactions.
Client requests are indicated with a solid line from the left and server responses are indicated with a dotted line from the right.
All requests below use POST
.
In the simplest transaction, the report contains no files:
In this transaction, the report contains only a single file:
In this transaction, the report contains one file with details and another file without details:
In this transaction, the reporter retracts the report after uploading a file:
6. Example (using curl)
To illustrate how a report is submitted, included is an example using curl. Executables and documentation for curl are available at https://curl.se. This example shows how to open a report, upload a file, submit file details about that file, and finish or cancel the report. For this illustration, the following base URI and example credentials will be used. Note that the username and password below are not valid credentials; you can use your NCMEC-provided credentials to follow along with this example.
-
The example base URI is the test environment: https://exttest.cybertip.org/ispws
-
The example username and password supplied by NCMEC is
usr123
andpswd123
The credentials used in this section are for illustration only. You must use your credentials provided by NCMEC. |
6.1. Open the Report
The report is submitted as an XML document with <report>
as the root element.
This is the first request made for a new report submission, which "opens" the report.
Below is an example of a simple report document.
Assume this XML file is located on the file system at /home/me/report.xml
.
<?xml version="1.0" encoding="UTF-8"?>
<report xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="https://report.cybertip.org/ispws/xsd">
<incidentSummary>
<incidentType>Child Pornography (possession, manufacture, and distribution)</incidentType>
<reportAnnotations>
<sextortion />
<csamSolicitation />
<minorToMinorInteraction />
<spam />
</reportAnnotations>
<incidentDateTime>2012-10-15T08:00:00-07:00</incidentDateTime>
</incidentSummary>
<internetDetails>
<webPageIncident>
<url>http://badsite.com/baduri.html</url>
</webPageIncident>
</internetDetails>
<reporter>
<reportingPerson>
<firstName>John</firstName>
<lastName>Smith</lastName>
<email>jsmith@example.com</email>
</reportingPerson>
</reporter>
</report>
The following curl command can be used to submit the report XML to the CyberTipline Reporting API.
curl --user 'usr123:pswd123' \
--header 'Content-Type: text/xml; charset=utf-8' \
--data @/home/me/report.xml \
https://exttest.cybertip.org/ispws/submit
Note that the UTF-8 character set is specified to ensure correct transmission of non-ASCII characters. |
The server’s response will indicate whether the report submission was successful and, if so, provide the report ID assigned to the report. The report ID will be used to submit files and file details, as well as to cancel or finish the report.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<reportResponse>
<responseCode>0</responseCode> (1)
<responseDescription>Success</responseDescription>
<reportId>4564654</reportId> (2)
</reportResponse>
1 | Response code 0 indicates successful report submission |
2 | Report ID assigned to the submitted report |
6.2. Upload a File
A request to upload a file requires the following parameters.
id
|
The report ID to which the uploaded file should be associated |
file
|
The actual file being uploaded |
Assume a file to be uploaded to the report opened in the prior example is located on the file system at /home/me/file.jpg
.
The following curl command can be used to upload the file to the report.
curl --user 'usr123:pswd123' \
--form id=4564654 \
--form file=@/home/me/file.jpg \
https://exttest.cybertip.org/ispws/upload
The server’s response will indicate whether the file upload was successful and, if so, the file ID and MD5 hash of the uploaded file. The file ID is used to submit file details for the uploaded file. The MD5 hash can be used to verify that the complete file was received.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<reportResponse>
<responseCode>0</responseCode> (1)
<responseDescription>Success</responseDescription>
<reportId>4564654</reportId> (2)
<fileId>b0754af766b426f2928a02c651ed4b99</fileId> (3)
<hash>fafa5efeaf3cbe3b23b2748d13e629a1</hash> (4)
</reportResponse>
1 | Response code 0 indicates successful file upload |
2 | Report ID for the report |
3 | File ID assigned to the uploaded file |
4 | MD5 hash of the uploaded file |
6.3. Submit File Details
Optional file details are submitted for an uploaded file as an XML document with <fileDetails>
as the root element.
Below is an example of a file details document for the file uploaded in the prior example.
Assume the file is located on the file system at /home/me/file-details.xml
.
<?xml version="1.0" encoding="UTF-8"?>
<fileDetails xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="https://report.cybertip.org/ispws/xsd">
<reportId>4564654</reportId> (1)
<fileId>b0754af766b426f2928a02c651ed4b99</fileId> (2)
<originalFileName>mypic.jpg</originalFileName>
<ipCaptureEvent>
<ipAddress>63.116.246.17</ipAddress>
<eventName>Upload</eventName>
<dateTime>2011-10-31T12:00:00Z</dateTime>
</ipCaptureEvent>
<additionalInfo>File was originally posted with 6 others</additionalInfo>
</fileDetails>
1 | Report ID assigned to the submitted report from report submission response |
2 | File ID assigned to the uploaded file from file upload response |
The following curl command can be used to submit the file details XML to the CyberTipline Reporting API. Note that the UTF-8 character set is specified to ensure correct transmission of non-ASCII characters.
curl --user 'usr123:pswd123' \
--header 'Content-Type: text/xml; charset=utf-8' \
--data @/home/me/file-details.xml \
https://exttest.cybertip.org/ispws/fileinfo
The server’s response will indicate whether the file details submission was successful.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<reportResponse>
<responseCode>0</responseCode> (1)
<responseDescription>Success</responseDescription>
<reportId>4564654</reportId>
</reportResponse>
1 | Response code 0 indicates successful file details submission |
6.4. Finish the Report
Once all the files and file details are uploaded, the report must be finished to complete submission.
A request to finish a report requires the parameter id
, the report ID of the report to finish.
The following curl command can be used to finish the report.
curl --user 'usr123:pswd123' \
--form id=4564654 \
https://exttest.cybertip.org/ispws/finish
The server’s response will indicate whether the finish was successful, the report ID, and the list of file IDs for the report.
The XML notification of receipt of a report made to NCMEC’s CyberTipline under 18 U.S.C. § 2258A shall serve as the ESP notification pursuant to 18 U.S.C. § 2258A(h)(1)). |
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<reportDoneResponse>
<responseCode>0</responseCode> (1)
<reportId>4564654</reportId> (2)
<files>
<fileId>b0754af766b426f2928a02c651ed4b99</fileId> (3)
</files>
</reportDoneResponse>
1 | Response code 0 indicates successful report finish |
2 | Report ID of the finished report |
3 | File IDs of the finished report |
6.5. Cancel the Report
Before the report is finished, it may be cancelled if the reporter encounters an error during submission.
A request to cancel a report requires the parameter id
, the report ID of the report to cancel.
The following curl command can be used to cancel the report.
curl --user 'usr123:pswd123' \
--form id=4564654 \
https://exttest.cybertip.org/ispws/retract
The server’s response will indicate whether the cancel was successful and the report ID of the cancelled report.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<reportResponse>
<responseCode>0</responseCode> (1)
<responseDescription>Success</responseDescription>
<reportId>4564654</reportId> (2)
</reportResponse>
1 | Response code 0 indicates successful report cancellation |
2 | Report ID of the cancelled report |
7. Troubleshooting
If you encounter problems using this web service, the following tips may help you with troubleshooting.
7.1. Status Endpoint
Verify that you can access the server and that your credentials are correct by accessing the status endpoint from a web browser. For production, navigate to https://report.cybertip.org/ispws/status. For testing, navigate to https://exttest.cybertip.org/ispws/status. Your browser will ask you to provide credentials. Verify that you receive the following response, where {username} represents your username and {ip address} represents your IP address.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<reportResponse>
<responseCode>0</responseCode>
<responseDescription>Remote User : {username}, Remote Ip : {ip address}</responseDescription>
</reportResponse>
If you receive the above response, you know that you can access the server and authenticate successfully. If you cannot, contact NCMEC to verify your credentials. Verify that you do not have any firewall rules that prevent you from connecting to NCMEC’s servers.
7.2. XML Validation
Verify that your XML is syntactically and structurally correct by validating it against the latest schema, available at https://report.cybertip.org/ispws/xsd.
It is recommended that model object code used for submissions be programmatically generated from the aforementioned XSD. This will ensure there are no errors in element tag names, document structure, or other easy-to-miss discrepancies. |
7.3. Timestamp Format
Make sure your date/time values are specified according to the ISO 8601 standard.
ISO 8601 timestamps must have a time zone specified in the format +/-hh:mm
or Z
for UTC.
7.4. curl
Try to submit a report to the testing environment at https://exttest.cybertip.org/ispws using curl as in example above. The example has been tested on both Linux and Windows.
7.5. Request IDs
If you are receiving error responses from the server and need assistance from NCMEC, please also include in your message the value of the Request-ID
header provided in the server response.
This will help NCMEC locate your API request to provide timelier and more useful troubleshooting assistance.
Appendix A: Common Types
Below is a description of common element types specified by the reporting schema.
Listed with each element or attribute is an indicator of the element’s or attribute’s cardinality.
Cardinality | Description |
---|---|
1 |
exactly one element is required |
1+ |
one or more elements is required |
0|1 |
element is optional but at most 1 element may be supplied |
0+ |
element is optional but there is no limit on the number that may be supplied |
In the event that a reporter chooses to voluntarily provide information for an element, certain parent, child, or sibling elements may also be required. Please refer to the XSD for the authoritative schema definition.
<ipCaptureEvent>
-
A capture of an IP address. For example, the IP address of the computer a user used to upload a child pornography picture and the time the upload happened.
<ipAddress>
1-
The IP address from which the event occurred.
type stringvalidation must be a valid IPv4, IPv6, or IPv4-mapped IPv6 addressvalidation must not be blank if<ipCaptureEvent>
supplied <eventName>
0|1-
The type of event from which the IP address was captured. One of:
-
Login
-
Registration
-
Purchase
-
Upload
-
Other
-
Unknown
type string -
<dateTime>
0|1-
The date and time the IP address was captured.
type ISO 8601 date and timevalidation must be in the past <possibleProxy>
0|1-
Whether the reporter has reason to believe this IP address is a proxy.
type boolean <port>
0|1-
The port number of the IP address.
type intvalidation must be between 1 and 65535
<deviceId>
-
A capture of a device ID. Similar to
<ipCaptureEvent>
. Used to report information such as ICCID or IMEI numbers associated with an event.<idType>
1-
The type of device ID captured (e.g., IMEI, ICCID, SSID).
type stringvalidation must not be blank if<deviceId>
suppliedvalidation max length is 255 characters <idValue>
1-
The device ID from which the event occurred.
type stringvalidation must not be blank if<deviceId>
suppliedvalidation max length is 2083 characters <eventName>
0|1-
The type of event from which the device ID was captured. One of:
-
Login
-
Registration
-
Purchase
-
Upload
-
Other
-
Unknown
type string -
<dateTime>
0|1-
The date and time the device ID was captured.
type ISO 8601 date and timevalidation must be in the past
<address>
-
A physical street address.
<address>
0|1-
Street address.
type stringvalidation max length is 255 characters <city>
0|1-
City.
type stringvalidation max length is 100 characters <zipCode>
0|1-
Zip or postal code.
type stringvalidation max length is 20 characters <state>
0|1-
US state or territory postal abbreviation.
type stringvalidation must be a valid US state or territory postal abbreviation <nonUsaState>
0|1-
State, province, or region if not in the United States.
type stringvalidation max length is 100 characters <country>
0|1-
ISO 3166-1 alpha-2 two-character country code.
type stringvalidation must be a valid ISO 3166-1 alpha-2 country code type
0|1attribute-
Type of address. One of:
-
Home
-
Business
-
Billing
-
Shipping
-
Technical
type string -
<phone>
-
A phone number.
type stringvalidation max length is 50 charactersvalidation ifcountryCallingCode
supplied, must not start with country calling codetype
0|1attribute-
Type of phone number. One of:
-
Mobile
-
Home
-
Business
-
Work
-
Fax
-
Internet
-
Recovery
type string -
verified
0|1attribute-
Whether the reporter has verified the phone number.
type booleanvalidation must betrue
whenverificationDate
is supplied verificationDate
0|1attribute-
The date and time that the reporter last verified the phone number.
type stringvalidation must be in the past countryCallingCode
0|1attribute-
The country calling code for the phone number.
type stringvalidation must conform to the regular expression\+[0-9]{1,3}
extension
0|1attribute-
The extension for the phone number.
type stringvalidation must conform to the regular expression[0-9]+
validation max length is 10 characters
<email>
-
An email address.
type stringvalidation must be a well-formed email addressvalidation max length is 255 characterstype
0|1attribute-
Type of email address. One of:
-
Home
-
Work
-
Business
-
Recovery
type string -
verified
0|1attribute-
Whether the reporter has verified the email address.
type booleanvalidation must betrue
whenverificationDate
is supplied verificationDate
0|1attribute-
The date and time that the reporter last verified the email address.
type stringvalidation must be in the past
<estimatedLocation>
-
An estimated location.
<city>
0|1-
The city of the estimated location.
type stringvalidation max length is 255 characters <region>
0|1-
The region of the estimated location.
type stringvalidation max length is 255 charactersvalidation must be a valid US state or territory postal abbreviation if supplied and<countryCode>
is "US"validation must be not be blank if<city>
is supplied and<countryCode>
is "US" <countryCode>
0|1-
ISO 3166-1 alpha-2 two-character country code of the estimated location.
type stringvalidation must be not be blank if<estimatedLocation>
is suppliedvalidation must be a valid ISO 3166-1 alpha-2 country code verified
0|1attribute-
Whether the reporter has verified the estimated location.
type boolean timestamp
0|1attribute-
The date and time the reporter made the location estimation.
type ISO 8601 date and timevalidation must be in the past
<person>
-
A real world person.
<firstName>
0|1-
The person’s first name.
type stringvalidation max length is 100 characters <lastName>
0|1-
The person’s last name.
type stringvalidation max length is 100 characters <phone>
0+-
A phone number.
type<phone>
<email>
0+-
An email address. At least one email address is required when used as part of the
<reportingPerson>
element.type<email>
<address>
0+-
A physical address.
type<address>
<age>
0|1-
The person’s approximate age.
type intvalidation must be between 0 and 150 <dateOfBirth>
0|1-
The person’s date of birth.
type ISO 8601 datevalidation must be in the past
<contactPerson>
-
A real world person with information pertinent for professional contact.
<firstName>
0|1-
The person’s first name.
type stringvalidation max length is 100 characters <lastName>
0|1-
The person’s last name.
type stringvalidation max length is 100 characters <phone>
0+-
A phone number.
type<phone>
<email>
0+-
An email address.
type<email>
<address>
0+-
A physical address.
type<address>
Appendix B: Report Details Types
Below is a description of report details element types specified by the reporting schema.
Listed with each element or attribute is an indicator of the element’s or attribute’s cardinality.
Cardinality | Description |
---|---|
1 |
exactly one element is required |
1+ |
one or more elements is required |
0|1 |
element is optional but at most 1 element may be supplied |
0+ |
element is optional but there is no limit on the number that may be supplied |
In the event that a reporter chooses to voluntarily provide information for an element, certain parent, child, or sibling elements may also be required. Please refer to the XSD for the authoritative schema definition.
<report>
-
The main top-level tag to define an incident report.
<batchedReport>
0|1-
Indicator that the report concerns multiple reported persons or users related to the reported incident.
reason
1attribute-
The reason for grouping multiple reported persons or users into a single batched report. Values include:
-
VIRAL_POTENTIAL_MEME
- The batched report concerns a file that is being shared/posted out of mimicry or other seemingly non-malicious intent or the file is circulating rapidly from one user to another. See Viral/Potential Meme Batched Reports for implications on report validation constraints.
type string -
<incidentSummary>
1-
General incident information.
type<incidentSummary>
<internetDetails>
0+-
Details of an incident being reported.
type<internetDetails>
<lawEnforcement>
0|1-
Law enforcement contact information if the incident information has already been reported to law enforcement or if the request originated from law enforcement.
type<lawEnforcement>
<reporter>
1-
Information related to the person or company reporting the incident.
type<reporter>
<personOrUserReported>
0|1-
The reported user or person involved in the incident. This person will be displayed as the suspect.
<intendedRecipient>
0+-
An intended recipient involved in the incident.
type<intendedRecipient>
<victim>
0+-
A child victim involved in the incident.
type<victim>
<additionalInfo>
0|1-
Additional notes on this incident not covered by any other section.
type string
B.1. Incident Summary
<incidentSummary>
-
General incident information.
<incidentType>
1-
The type of incident being reported. Values include:
-
Child Pornography (possession, manufacture, and distribution)
-
Child Sex Trafficking
-
Child Sex Tourism
-
Child Sexual Molestation
-
Misleading Domain Name
-
Misleading Words or Digital Images on the Internet
-
Online Enticement of Children for Sexual Acts
-
Unsolicited Obscene Material Sent to a Child
type string -
<platform>
0|1-
The full application name where the reported content occurred.
type stringvalidation max length is 256 characters <escalateToHighPriority>
0|1-
A reason for a higher level of urgency, e.g. immediate risk to child. Supplying a value will escalate the report.
type stringvalidation must not be blank if<escalateToHighPriority>
suppliedvalidation max length is 3000 characters <reportAnnotations>
0|1-
Tags to describe the report.
type<reportAnnotations>
<incidentDateTime>
1-
The date, time, and time zone of the reported incident.
type ISO 8601 date and timevalidation must be in the past <incidentDateTimeDescription>
0|1-
Additional information related to the
<incidentDateTime>
.type stringvalidation max length is 3000 characters
B.1.1. Report Annotations
<reportAnnotations>
-
Tags to describe the report.
<sextortion>
0|1-
The report is associated with sextortion.
<csamSolicitation>
0|1-
The report is associated with solicitation of child sexual assault material (CSAM).
<minorToMinorInteraction>
0|1-
The report is associated with an interaction between minors.
<spam>
0|1-
The report is associated with spam.
B.2. Internet Details
<internetDetails>
-
Details of an incident being reported. Each supplied
<internetDetails>
element must have exactly one of the following:<webPageIncident>
-
Details for an incident that occurred on a web page.
type<webPageIncident>
<emailIncident>
-
Details for an incident that occurred over email.
type<emailIncident>
<newsgroupIncident>
-
Details for an incident that occurred in a newsgroup.
type<newsgroupIncident>
<chatImIncident>
-
Details for an incident that occurred over IM or during a chat session.
type<chatImIncident>
<onlineGamingIncident>
-
Details for an incident that occurred during an online game.
<cellPhoneIncident>
-
Details for an incident that occurred when the primary method of communication between the child and/or reported person or user was through a cell phone. This can include phone conversations, text messages, or images sent via a cell phone.
type<cellPhoneIncident>
<nonInternetIncident>
-
Details for an incident that does not involve an online or computer component or a cell phone (e.g., face-to-face contact, potentially illegal hard copy or printed materials).
<peer2peerIncident>
-
Details for an incident that occurred via a peer-to-peer (also known as P2P) decentralized network that allows users to share files through a direct connection.
type<peer2peerIncident>
B.2.1. Web Page Incident
<webPageIncident>
-
Details for an incident that occurred on a web page.
<url>
0+-
An actual URL where the reported incident occurred.
type stringvalidation must be a valid URLvalidation max length is 2083 characters <additionalInfo>
0|1-
Additional information related to the web page event.
type string thirdPartyHostedContent
0|1attribute-
Whether the reported URL is hosted on another company’s server and the reporter has no further information on this incident and is providing it to NCMEC for informational purposes.
type boolean
B.2.2. Email Incident
<emailIncident>
-
Details for an incident that occurred over email.
<emailAddress>
0+-
An email address associated with the incident.
type<email>
validation must also be supplied as a<personOrUserReported>
email address,<intendedRecipient>
email address, or a<victim>
email address <content>
0|1-
The headers, subject, and content of the communication.
type string <additionalInfo>
0|1-
Additional information about the email incident not covered by any other section.
type string
B.2.3. Newsgroup Incident
<newsgroupIncident>
-
Details for an incident that occurred in a newsgroup.
<name>
0|1-
The newsgroup name.
type stringvalidation max length is 255 characters <emailAddress>
0+-
An email address associated with the incident.
type<email>
validation must also be supplied as a<personOrUserReported>
email address,<intendedRecipient
email address, or a<victim>
email address <content>
0|1-
The headers, subject, and content of the communication.
type string <additionalInfo>
0|1-
Additional information about the newsgroup incident not covered by any other section.
type string
B.2.4. Chat/IM Incident
<chatImIncident>
-
Details for an incident that occurred over IM or during a chat session.
<chatClient>
0|1-
The chat or instant messenger program used.
type stringvalidation max length is 255 characters <chatRoomName>
0|1-
The name of the chat room.
type stringvalidation max length is 255 characters <content>
0|1-
The content of the chat.
type string <additionalInfo>
0|1-
Additional information about the chat or instant messaging incident not covered by any other section.
type string
B.2.5. Online Gaming Incident
<onlineGamingIncident>
-
Details for an incident that occurred during an online game.
<gameName>
0|1-
The name of the game in which the incident occurred.
type stringvalidation max length is 255 characters <console>
0|1-
The name of the gaming console used in the incident.
type stringvalidation max length is 255 characters <content>
0|1-
The content of the message/chat that occurred during the game.
type string <additionalInfo>
0|1-
Additional information about the online gaming incident not covered by any other section.
type string
B.2.6. Cellphone Incident
<cellPhoneIncident>
-
Details for an incident that occurred when the primary method of communication between the child and/or reported person or user was through a cell phone. This can include phone conversations, text messages, or images sent via a cell phone.
<phoneNumber>
0|1-
The cell phone number associated with the incident.
type<phone>
<latitude>
0|1-
The latitude associated with the incident.
type double <longitude>
0|1-
The longitude associated with the incident.
type double <additionalInfo>
0|1-
Additional information about the cell phone incident not covered by any other section.
type string
B.2.7. Non-Internet Incident
<nonInternetIncident>
-
Details for an incident that does not involve an online or computer component or a cell phone (e.g., face-to-face contact, potentially illegal hard copy or printed materials).
<locationName>
0|1-
The location associated with the incident.
type stringvalidation max length is 255 characters <incidentAddress>
0+-
The address of the incident.
type<address>
<additionalInfo>
0|1-
Additional information about the incident not covered by any other section.
type string
B.2.8. Peer-to-Peer Incident
<peer2peerIncident>
-
Details for an incident that occurred via a peer-to-peer (also known as P2P) decentralized network that allows users to share files through a direct connection.
<client>
0|1-
The peer-to-peer client associated with the incident.
type stringvalidation max length is 255 characters <ipCaptureEvent>
0+-
An IP address used by the person or user reported.
type<ipCaptureEvent>
<fileNames>
0|1-
The name of the file(s) associated with the incident.
type string <additionalInfo>
0|1-
Additional information about the peer-to-peer incident not covered by any other section.
type string
B.3. Law Enforcement
<lawEnforcement>
-
Law enforcement contact information if the incident information has already been reported to law enforcement or if the request originated from law enforcement.
<agencyName>
1-
The law enforcement agency name.
type stringvalidation max length is 255 characters <caseNumber>
0|1-
The law enforcement agency case number.
type stringvalidation max length is 100 characters <officerContact>
0|1-
Information about the investigator or officer assigned to the case.
type<contactPerson>
<reportedToLe>
0|1-
Whether the incident was reported to law enforcement by the reporter.
type boolean <servedLegalProcessDomestic>
0|1-
Whether domestic law enforcement has served legal process about this person/user or reported incident.
type boolean <servedLegalProcessInternational>
0|1-
Whether international law enforcement has served legal process about this person/user or reported incident.
type booleanfleaCountry
0|1attribute-
The country associated with this report from which legal process was received.
type stringvalidation must be a valid ISO 3166-1 alpha-2 country code
B.4. Reporter
<reporter>
-
Information related to the person or company reporting the incident.
-
<reportingPerson>
1 -
Information about the person reporting the incident. The email element of this element is required, however the XML notification of receipt of a report made to NCMEC’s CyberTipline under 18 U.S.C. § 2258A shall serve as the ESP notification pursuant to 18 U.S.C. § 2258A(h)(1).
type<person>
validation<email>
is required <contactPerson>
0|1-
Information about a person who should be contacted by law enforcement regarding the report other than the person submitting the report.
type<contactPerson>
<companyTemplate>
0|1-
Language (not specific to the reported incident) that the reporting company wants included in the CyberTipline report, e.g., basic company information, how legal process should be served, length of data retention, 24-hour emergency phone numbers.
type string <termsOfService>
0|1-
Terms of Service (TOS) relevant to the incident being reported.
type string <legalURL>
0|1-
A URL for a web page with further information.
type stringvalidation must be a valid URLvalidation max length is 2083 characters
-
B.5. Reported Person
<personOrUserReported>
-
A reported user or person involved in the incident. This person will be displayed as the suspect.
<personOrUserReportedPerson>
0|1-
Information about the reported person or user involved in the incident.
type<person>
<vehicleDescription>
0|1-
Description of the vehicle of the reported person.
type stringvalidation max length is 300 characters <espIdentifier>
0|1-
The unique ID of the reported person or user in the reporter’s system.
type stringvalidation max length is 255 characters <espService>
0|1-
The name of the reporter’s product or service that was used by the reported person or user during the incident.
type stringvalidation max length is 100 characters <compromisedAccount>
0|1-
This account has been compromised, hacked, or hijacked.
type boolean <screenName>
0|1-
The screen/user name of the reported person or user.
type stringvalidation max length is 255 characters <displayName>
0+-
A display name, other than a screen name or a username, for the reported person or user.
type stringvalidation max length is 255 characters <profileUrl>
0+-
An identifying URL for the reported person or user.
type stringvalidation must be a valid URLvalidation max length is 2083 characters <profileBio>
0|1-
A copy of the user’s bio as per their account according to the reporting company’s platform.
type string <ipCaptureEvent>
0+-
An IP address used by the reported person or user.
type<ipCaptureEvent>
<deviceId>
0+-
An ID for a device used by the reported person or user.
type<deviceId>
<thirdPartyUserReported>
0|1-
Whether the reported person or user is using another company’s service and the reporting company has no further information about this person or user.
type boolean <priorCTReports>
0+-
A report ID for a prior CyberTipline report on this reported person or user.
type longvalidation must be a valid CyberTipline report ID <groupIdentifier>
0|1-
Unique group identifiers (e.g., group name, group ID) if the reporter believes the reported person or user is engaged in an online group related to child sexual exploitation.
type stringvalidation max length is 255 characters <accountTemporarilyDisabled>
0|1-
Whether the account was temporarily disabled at any point.
type booleandisabledDate
0|1attribute-
The date the account was temporarily disabled.
type ISO 8601 date and timevalidation must be in the past userNotified
0|1attribute-
Has user been notified that account was temporarily disabled.
type boolean userNotifiedDate
0|1attribute-
The date/time user was notified account was temporarily disabled.
type ISO 8601 date and timevalidation must be in the pastvalidation must be on or after thedisabledDate
if both are supplied reenabledDate
0|1attribute-
The date the temporarily disabled account was re-enabled.
type ISO 8601 date and timevalidation must be after thedisabledDate
if both are supplied
<accountPermanentlyDisabled>
0|1-
Whether the account was permanently disabled.
type booleandisabledDate
0|1attribute-
The date the account was permanently disabled.
type ISO 8601 date and timevalidation must be in the past userNotified
0|1attribute-
Has user been notified that account was permanently disabled.
type boolean userNotifiedDate
0|1attribute-
The date/time user was notified account was permanently disabled.
type ISO 8601 date and timevalidation must be in the pastvalidation must be on or after thedisabledDate
if both are supplied
<estimatedLocation>
0|1-
The reporter’s estimated location for the reported person or user.
type<estimatedLocation>
<allEmailsReported>
0|1-
There are no additional emails to report.
type boolean <additionalInfo>
0|1-
Additional information about this reported person or user not covered by any other section.
type string
B.6. Intended Recipient
<intendedRecipient>
-
The intended recipient involved in the incident.
<intendedRecipientPerson>
0|1-
Information about the intended recipient in the incident.
type<person>
<espIdentifier>
0|1-
The unique ID of the intended recipient in the reporter’s system.
type stringvalidation max length is 255 characters <espService>
0|1-
The name of the reporter’s product or service that was used by the intended recipient during the incident.
type stringvalidation max length is 100 characters <compromisedAccount>
0|1-
This account has been compromised, hacked, or hijacked.
type boolean <screenName>
0|1-
The screen name of the intended recipient.
type stringvalidation max length is 255 characters <displayName>
0+-
A display name, other than a screen name or a username, for the intended recipient.
type stringvalidation max length is 255 characters <profileUrl>
0+-
An identifying URL for the intended recipient.
type stringvalidation must be a valid URLvalidation max length is 2083 characters <profileBio>
0|1-
A copy of the user’s bio as per their account according to the reporting company’s platform.
type string <ipCaptureEvent>
0+-
An IP address used by the intended recipient.
type<ipCaptureEvent>
<deviceId>
0+-
An ID for a device used by the intended recipient.
type<deviceId>
<priorCTReports>
0+-
A report ID for a prior CyberTipline report on this intended recipient.
type longvalidation must be a valid CyberTipline report ID <groupIdentifier>
0|1-
Unique group identifiers (e.g., group name, group ID) if the reporter believes the intended recipient is engaged in an online group related to child sexual exploitation.
type stringvalidation max length is 255 characters <accountTemporarilyDisabled>
0|1-
Whether the account was temporarily disabled at any point.
type booleandisabledDate
0|1attribute-
The date the account was temporarily disabled.
type ISO 8601 date and timevalidation must be in the past userNotified
0|1attribute-
Has user been notified that account was temporarily disabled.
type boolean userNotifiedDate
0|1attribute-
The date/time user was notified account was temporarily disabled.
type ISO 8601 date and timevalidation must be in the pastvalidation must be on or after thedisabledDate
if both are supplied reenabledDate
0|1attribute-
The date the temporarily disabled account was re-enabled.
type ISO 8601 date and timevalidation must be after thedisabledDate
if both are supplied
<accountPermanentlyDisabled>
0|1-
Whether the account was permanently disabled.
type booleandisabledDate
0|1attribute-
The date the account was permanently disabled.
type ISO 8601 date and timevalidation must be in the past userNotified
0|1attribute-
Has user been notified that account was permanently disabled.
type boolean userNotifiedDate
0|1attribute-
The date/time user was notified account was permanently disabled.
type ISO 8601 date and timevalidation must be in the pastvalidation must be on or after thedisabledDate
if both are supplied
<estimatedLocation>
0|1-
The reporter’s estimated location for the intended recipient.
type<estimatedLocation>
<allEmailsReported>
0|1-
There are no additional emails to report.
type boolean <additionalInfo>
0|1-
Additional information about this intended recipient not covered by any other section.
type string
B.7. Child Victim
<victim>
-
A child victim involved in the incident.
<victimPerson>
1-
Information about the child victim involved in the incident.
type<person>
<espIdentifier>
0|1-
The unique ID of the child victim in the reporter’s system.
type stringvalidation max length is 255 characters <espService>
0|1-
The name of the reporter’s product or service that was used by the child victim during the incident.
type stringvalidation max length is 100 characters <compromisedAccount>
0|1-
This account has been compromised, hacked, or hijacked.
type boolean <screenName>
0|1-
The screen name of the child victim.
type stringvalidation max length is 255 characters <displayName>
0+-
A display name, other than a screen name or a username, for the child victim.
type stringvalidation max length is 255 characters <profileUrl>
0+-
An identifying URL for the child victim.
type stringvalidation must be a valid URLvalidation max length is 2083 characters <profileBio>
0|1-
A copy of the user’s bio as per their account according to the reporting company’s platform.
type string <ipCaptureEvent>
0+-
An IP address used by the child victim.
type<ipCaptureEvent>
<deviceId>
0+-
An ID for a device used by the child victim.
type<deviceId>
<schoolName>
0|1-
The school name of the child victim.
type stringvalidation max length is 255 characters <priorCTReports>
0+-
A report ID for a prior CyberTipline report on this child victim.
type longvalidation must be a valid CyberTipline report ID <allEmailsReported>
0|1-
Have all email addresses been reported.
type boolean <accountTemporarilyDisabled>
0|1-
Whether the account was temporarily disabled at any point.
type booleandisabledDate
0|1attribute-
The date the account was temporarily disabled.
type ISO 8601 date and timevalidation must be in the past userNotified
0|1attribute-
Has user been notified that account was temporarily disabled.
type boolean userNotifiedDate
0|1attribute-
The date/time user was notified account was temporarily disabled.
type ISO 8601 date and timevalidation must be in the pastvalidation must be on or after thedisabledDate
if both are supplied reenabledDate
0|1attribute-
The date the temporarily disabled account was re-enabled.
type ISO 8601 date and timevalidation must be after thedisabledDate
if both are supplied
<accountPermanentlyDisabled>
0|1-
Whether the account was permanently disabled.
type booleandisabledDate
0|1attribute-
The date the account was permanently disabled.
type ISO 8601 date and timevalidation must be in the past userNotified
0|1attribute-
Has user been notified that account was permanently disabled.
type boolean userNotifiedDate
0|1attribute-
The date/time user was notified account was permanently disabled.
type ISO 8601 date and timevalidation must be in the pastvalidation must be on or after thedisabledDate
if both are supplied
<estimatedLocation>
0|1-
The reporter’s estimated location for the child victim.
type<estimatedLocation>
<allEmailsReported>
0|1-
There are no additional emails to report.
type boolean <additionalInfo>
0|1-
Additional information about this child victim not covered by any other section.
type string
Appendix C: File Details Types
Below is a description of file details element types specified by the reporting schema.
Listed with each element or attribute is an indicator of the element’s or attribute’s cardinality.
Cardinality | Description |
---|---|
1 |
exactly one element is required |
1+ |
one or more elements is required |
0|1 |
element is optional but at most 1 element may be supplied |
0+ |
element is optional but there is no limit on the number that may be supplied |
In the event that a reporter chooses to voluntarily provide information for an element, certain parent, child, or sibling elements may also be required. Please refer to the XSD for the authoritative schema definition.
<fileDetails>
-
Details about a file.
<reportId>
1-
The report ID to which the details are related.
type longvalidation must be a valid CyberTipline report IDvalidation reporter must have permission to update the supplied CyberTipline Report <fileId>
1-
The file ID to which the details are related.
type stringvalidation must not be blankvalidation must be a valid file ID for the supplied report ID <originalFileName>
0|1-
The original filename associated with the file when it was uploaded to the company’s servers by the reported user or person.
type stringvalidation max length is 2056 characters <uploadedToEspTimestamp>
0|1-
The date and time the file was uploaded to the reporting ESP.
type ISO 8601 date and timevalidation must be in the past <locationOfFile>
0|1-
The URL where file was originally located.
type stringvalidation must be a valid URLvalidation max length is 2083 characters <fileViewedByEsp>
0|1-
Whether the reporting company viewed the entire contents of the file being reported to NCMEC.
type booleanvalidation must be "true" when the value of<exifViewedByEsp>
is "true" <exifViewedByEsp>
0|1-
Whether the reporting company viewed the EXIF for the file being reported to NCMEC.
type boolean <publiclyAvailable>
0|1-
Whether the entire contents of the file were publicly accessible to online users.
type boolean <fileRelevance>
0|1-
The relevance or relation of the file to the report. Unless specified otherwise, a file is "Reported" by default. One of the following values:
- Reported
-
Content that is the motivation for making the CyberTipline report, according to the chosen incident type. Only "Reported" files may be identified as potential meme or be given an industry classification.
- Supplemental Reported
-
Supplementary content that provides contextual value to the report. A part of the communication containing apparent child pornography, including any data or information regarding the transmission of the communication or any images, data, or other digital files contained in, or attached to, the communication (18 U.S. Code § 2258A (b)(5)).
type stringvalidation may not be "Supplemental Reported" if a potential meme annotation is suppliedvalidation may not be "Supplemental Reported" if an<industryClassification>
is supplied <fileAnnotations>
0|1-
Tags to describe the file.
type<fileAnnotations>
<industryClassification>
0|1-
A categorization from the ESP-designated categorization scale. One of:
-
A1
-
A2
-
B1
-
B2
type string -
<originalFileHash>
0+-
The original binary hash value of the file at the time it was uploaded by the reported user or person (prior to any potential modification by the reporter).
type<originalFileHash>
<ipCaptureEvent>
0|1-
An IP address associated with the file.
type<ipCaptureEvent>
<deviceId>
0+-
An ID for a device associated with the file.
type<deviceId>
<details>
0+-
Metadata associated with the file.
type<details>
<additionalInfo>
0+-
Additional information about this file not covered by any other section.
type string
C.1. File Annotations
<fileAnnotations>
-
Tags to describe a file.
<animeDrawingVirtualHentai>
0|1-
The file is depicting anime, drawing, cartoon, virtual or hentai.
<potentialMeme>
0|1-
The file is being shared/posted out of mimicry or other seemingly non-malicious intent.
<viral>
0|1-
The file is circulating rapidly from one user to another.
<possibleSelfProduction>
0|1-
The file contains content that is believed to be self-produced.
<physicalHarm>
0|1-
The file depicts an intentional act of causing physical injury or trauma to a person.
<violenceGore>
0|1-
The file depicts graphic violence, including but not limited to acts of brutality or detailed or vivid gruesomeness.
<bestiality>
0|1-
The file involves an animal.
<liveStreaming>
0|1-
The file depicts content that was streamed live at the time it was uploaded.
<infant>
0|1-
The file depicts an infant.
<generativeAi>
0|1-
The file contains content that is believed to be Generative Artificial Intelligence.
C.2. Original File Hash
<originalFileHash>
-
An original file hash value.
type stringhashType
1attribute-
The type of hash (e.g. MD5, SHA1).
type stringvalidation max length is 64 characters
C.3. Details
<details>
-
Metadata associated with a file.
<nameValuePair>
1+-
A metadata entry.
<name>
1-
The name of the metadata entry.
type stringvalidation max length is 64 characters <value>
1-
The value of the metadata entry.
type string
type
0|1attribute-
The type of the metadata entry. One of:
-
EXIF
-
HASH
type string -
Appendix D: Response Types
Below is a description of response element types specified by the reporting schema.
Listed with each element or attribute is an indicator of the element’s or attribute’s cardinality.
Cardinality | Description |
---|---|
1 |
exactly one element will be supplied |
1+ |
one or more elements will be supplied |
0|1 |
element is optional but at most 1 element will be supplied |
0+ |
element is optional but there is no limit on the number that may be supplied |
Please refer to the XSD for the authoritative schema definition.
D.1. Report Response
<reportResponse>
-
The root element of the response to a report, file, or file details submittal.
<responseCode>
1-
The response code returned from the submittal. 0 is success, any non-zero number is an error code. The following is a non-exhaustive list of possible error codes.
0 Success
1000 Server error
1100 Save failed
1110 Upload failed
1111 File upload failed
1210 Resource not found
1300 Update failed
2000 Authentication required
3000 User is not authorized to perform this action
3100 User does not have authorization to make submissions
3300 User does not have authorization to make updates
4000 Invalid request
4100 Validation failed
4110 Malformed XML submittal
4200 Malformed file submittal
5001 Report does not exist
5002 File does not exist
5101 Report already retracted
5102 Report already finished
type int <responseDescription>
1-
The description of the response code.
type string <reportId>
1-
The report ID to which this response is related.
type long <fileId>
0|1-
If a file was successfully uploaded, the file ID for the file.
type string <hash>
0|1-
If a file was successfully uploaded, the MD5 hash of the file.
type string
D.2. Report Done Response
<reportDoneResponse>
-
The final response from the server once the report has been submitted, all files and file details have been uploaded, and the has been finished.
<responseCode>
1-
The response code returned from the submittal. 0 is success, any non-zero number is an error code. The following is a non-exhaustive list of possible error codes.
0 Success
1000 Server error
1100 Save failed
1110 Upload failed
1111 File upload failed
1210 Resource not found
1300 Update failed
2000 Authentication required
3000 User is not authorized to perform this action
3100 User does not have authorization to make submissions
3300 User does not have authorization to make updates
4000 Invalid request
4100 Validation failed
4110 Malformed XML submittal
4200 Malformed file submittal
5001 Report does not exist
5002 File does not exist
5101 Report already retracted
5102 Report already finished
type int <reportId>
1-
The report ID for the finished report.
type long <files>
1-
A list of file IDs for files successfully uploaded to the report.
<fileId>
0+-
A file ID for a file successfully uploaded to the report.
type long
Appendix E: Batched Report Validation
To activate a batched report, add element <batchedReport>
under the <report>
element.
This element must specify a reason
attribute indicating the rationale for submitting a batched report.
Elements and attributes in this section are indicated in XPath notation.
E.1. Viral/Potential Meme Batched Reports
The Viral/Potential Meme batched report mode is activated when the reason
attribute of the <batchedReport>
element is VIRAL_POTENTIAL_MEME
.
When the Viral/Potential Meme batched report mode is activated, the following validation rules apply to the main report submission.
-
Multiple
/report/personOrUserReported
elements are allowed. -
The only elements allowed within a
/report/personOrUserReported
element are following:-
/report/personOrUserReported/espIdentifier
-
-
None of the following elements or their child elements are allowed:
-
/report/incidentSummary/escalateToHighPriority
-
/report/internetDetails
-
/report/lawEnforcement
-
/report/intendedRecipient
-
/report/victim
-
/report/additionalInfo
-
When the Viral/Potential Meme batched report mode is activated, only 1 uploaded file is allowed.
If more than 1 uploaded file is included in the report, the call to complete the report via the /finish
endpoint will fail with a validation error (HTTP status 400 and application status 4100).
In this situation, the reporter should execute a retraction of the report via the /retract
endpoint and resubmit the report according to the validation rules specified in this section.
If the report is not retracted by the reporter, it will be automatically retracted by NCMEC after the default abandonment period has passed.
When the Viral/Potential Meme batched report mode is activated, the following validation rules apply to file details submissions.
-
The file must be annotated as viral and/or potential meme via the
/fileDetails/fileAnnotations/viral
and/or/fileDetails/fileAnnotations/potentialMeme
elements. -
The file may optionally be annotated with an industry classification via the
/fileDetails/industryClassification
element. -
The file may not indicate any other annotation; none of the following elements are allowed:
-
/fileDetails/fileAnnotations/animeDrawingVirtualHentai
-
/fileDetails/fileAnnotations/possibleSelfProduction
-
/fileDetails/fileAnnotations/physicalHarm
-
/fileDetails/fileAnnotations/violenceGore
-
/fileDetails/fileAnnotations/bestiality
-
/fileDetails/fileAnnotations/liveStreaming
-
/fileDetails/fileAnnotations/infant
-
/fileDetails/fileAnnotations/generativeAi
-
-
None of the following elements or their child elements are allowed:
-
/fileDetails/originalFileName
-
/fileDetails/locationOfFile
-
/fileDetails/originalFileHash
-
/fileDetails/ipCaptureEvent
-
/fileDetails/deviceId
-
/fileDetails/details
-
/fileDetails/additionalInfo
-
-
The relevance of the file specified by the
/fileDetails/fileRelevance
element must be "Reported".