CrowdMob (http://deals.crowdmob.com/) drives installs of your Android or iPhone mobile app. As long as you collect the required information on your server, you can integrate with CrowdMob to track unique installs of your app through a pure server-to-server solution, requiring no modification of your mobile app. This document details the rationale as well as the integration steps for this server-to-server solution.
Every time we drive an install of your application, your server should call our server with a POST to the following URL:
https://deals.crowdmob.com/crave/verify_install.json?permalink=<your permalink>&uuid_type=<your uuid type>&uuid=<your uuid>&secret_hash=<your secret hash>
your permalink
is the unique ID of your application on our server, generated by your CrowdMob contact, or by our server when you registered the application.your uuid type
ismac_address
(iOS & Android), orandroid_id
,android_serial_number
,android_telephony_id
, depending on which of these device identifiers your server collects.uuid
: The device identifier, either the Android ID, the Android serial number, the Android telephony ID, or the MAC address.secret_hash
: A SHA-256 hash of the following string:<secret_key> + <permalink> + ‘,’ + <udid_type> + ‘,’ + <udid>
. (Note that there is no comma between the secret key and the permalink.)
That's it! The long version follows, if you'd like a detailed explanation.
- The mobile application launches an install campaign with CrowdMob. (Done by mobile app developer.)
- A user sees an advertisement powered by CrowdMob.
- CrowdMob registers the user’s device with the CrowdMob server. Optionally, CrowdMob can issue a POST with the device information so the mobile app developer knows the device was referred by CrowdMob.
- The user installs the mobile app through either Apple's App Store or Google's Play Store.
- On first run, the mobile app registers the user’s device with the mobile app's server. (Implemented by mobile app developer.)
- The mobile app server reports the install to the CrowdMob server. (Implemented by mobile app developer.)
- The CrowdMob server provides stats to the mobile app developer.
Your server has to report app installs that can be matched against CrowdMob store installs on CrowdMob’s server. The CrowdMob store collects all of the following unique device identifiers for each device, so your server has to collect one of the following as well:
In order of preference on Android:
- Android ID (http://developer.android.com/reference/android/provider/Settings.Secure.html#ANDROID_ID)
- Serial number (http://developer.android.com/reference/android/os/Build.html#SERIAL)
- MAC address [hashed, encrypted, or plain-text] (http://developer.android.com/reference/android/net/wifi/WifiInfo.html#getMacAddress())
- Telephony ID (http://developer.android.com/reference/android/telephony/TelephonyManager.html#getDeviceId())
On iOS:
- MAC address [hashed, encrypted, or plain-text] (http://stackoverflow.com/questions/677530/how-can-i-programmatically-get-the-mac-address-of-an-iphone)
For both Android and iOS, the CrowdMob server stores encrypted MAC addresses to avoid a potential security concern regarding storing MAC addresses in plain text. CrowdMob uses the secure HTTPS protocol to prevent vulnerabilities in transmitting MAC addresses in plain text. CrowdMob also allows for you to transmit hashed or encrypted MAC addresses if you supply your hash or encryption scheme to our engineers.
If you collect any of the noted device identifiers on your server, you’ll be able to integrate using a pure server-to-server solution. If you don’t collect any of these device identifiers on your server, you’ll need to modify your server-side and mobile software to collect at least one of these identifiers.
Now that you’re collecting the required information, your server can report an install to CrowdMob’s server. In order to report an install, your server must issue an HTTP POST request to https://deals.crowdmob.com/crave/verify_install.json. The POST request parameters must be as follows:
permalink
: The permalink generated for your app when you registered your app with CrowdMob.uuid_type
: Eitherandroid_id
,android_serial_number
,mac_address
, orandroid_telephony_id
, depending on which of these device identifiers your server collects.uuid
: The device identifier, either the Android ID, the Android serial number, the Android telephony ID, or the MAC address.secret_hash
: A SHA-256 hash of the following string:<secret_key> + <permalink> + ‘,’ + <udid_type> + ‘,’ + <udid>
. (Note that there is no comma between the secret key and the permalink.)
You get your app’s secret key and permalink when you register your app with CrowdMob, and your mobile app and/or server must compute the user’s device’s UDID.
The following JSON expression represents the parameters that you should send to CrowdMob's server:
{ permalink: <your permalink>, uuid_type: <your uuid type>, uuid: <your uuid>, secret_hash: <your secret hash> }
Your final url should look like the following:
https://deals.crowdmob.com/crave/verify_install.json?permalink=<your permalink>&uuid_type=<your uuid type>&uuid=<your uuid>&secret_hash=<your secret hash>
Once your server has issued the POST request, CrowdMob’s server returns an HTTP status code. The HTTP status codes mean:
400
: At least one HTTP POST parameter was not supplied.403
: Your security hash doesn’t match the expected value.404
: Your specified app permalink doesn’t correspond to an app registered with CrowdMob.200
: Your request was well formed and was properly processed by CrowdMob’s server.
Look at some example source code in:
CrowdMob (http://deals.crowdmob.com/) can also track events that occur after an install, and provide reporting around it.
Currently this is only enabled for networks like hasoffers, although we are working hard to make it available for individual publishers too.
Just POST to our server, and we'll record it! You can append any extra values you would like and we will track them too.
POST https://deals.crowdmob.com/crave/events/network_create.json?network=<CROWDMOB_NETWORK_PERMALINK>&crowdmob_clickid=<CROWDMOB_CLICK_UUID>&eventid=<UNIQUE_EVENT_ID_ON_NETWORK>&payout=<AMOUNT_IN_USD_CROWDMOB_EARNED_FOR_THIS>&revenue=<REVENUE_IN_USD_ADVERTISER_GENERATED_FOR_THEMSELVES>...
There are 3 possible return values:
- For success, we will return the ID of the event in our system created, like:
{"id": 1234567890 }
- For an error, we will return a has with an "errors" key, like
{"errors":{"network_event_uuid":["has already been taken"]}}
- A
404
Not Found will be returned if CrowdMob couldn't identify your network by the permalink specified, or the click couldn't be found in our system bycrowdmob_clickid
.