Alternative device identifiers #36
Replies: 12 comments 33 replies
-
Can an alternative device identifier be returned that identifies the device to the API consumer, but cannot be used by any third-party to identify the device? It could - i.e. an opaque reference that can only be resolved by the issuing operator. Does the API consumer need to be able to derive the IMEI from this identifier, or just know that all devices with the same identifier are the same device? I suspect to be useful we would want the latter - otherwise we would just use the IMEI. Do any existing device identifiers satisfy this requirement? Would hashing the MSISDN with an API consumer salt be sufficient? Not sure. What happens if the MSISDN is ported to another operator? How is any alternative identifier derived, and how is it used by the API consumer? For further discussion :) - by 'used' do you mean use case scenarios? |
Beta Was this translation helpful? Give feedback.
-
Sorry, that was a typo. Should have been "Would hashing the IMEI with an API consumer salt be sufficient?". I'll edit.
Yes, I mean what is the use case for the device identifier information. For example, for insurance purposes, the insurance company may well require to know the IMEI. But for fraud detection, they may just need to know that the device currently being used by their customer is different to the one that they were using previously and had insured. |
Beta Was this translation helpful? Give feedback.
-
In general , there are 2 kinds of applications for device identifiers. One is a blacklist (or a grey list) of devices that have been used by fraudsters, or devices that have been stolen. For these list to be effective, it is indeed required that multiple independent parties can work with such a list. For this, IMEI as a device identifier is more suitable, although you run the risk that these IMEI's can be abused to track and trace people. Probably the only way to solve this is by having stringent rules on who can use this kind of information, which cases are approved, and to have transparency on both the legal basis for the use cases and who is using the data and for what purpose. For case of fraud consent will not work as a legal basis (because fraudsters will not give consent, and then you can not block access to a service), but only legitimate interest can be used. For ownership of devices and blokcing stolen devices, consent can be used as a legal basis. The other main application is that of a whitelist of devices, ranging from a short list of devices that can be used by a specific user (as a possesion factor in authentication), to a list of devices which belong to trusted users. For whitelists of devices, an alternate device identifier can be much more privacy friendly, in case the identifiers are only relevant for a specific application (or service provider), and can not be used to track users across different applications. This alternate device identifier can for example be generated by hashing the IMEI in combination with a sufficient long Salt (which needs to be application specific), or the MNO can generate random identifiers and store there with the IMEI in a table for future lookup. In this case of alternate identifiers, you probably also don't need to acquire users consent, because it is similar to the use of a functional cookie, which can be used without acquiring consent. The main advantage of such a white list based alternate device identifiers is that it can be made resilient towards factory resets of the device. |
Beta Was this translation helpful? Give feedback.
-
So you discuss two (physical) device identifiers:
My comments on the salted and hashed IMEI are:
So currently I do not see value in using salted & hashed IMEI as an alternative device identifier, but am open to persuasion! |
Beta Was this translation helpful? Give feedback.
-
I do not see the difficulties with a salted/hashed IMEI as a PPID. The API consumer opens the browser on the mobile device (on-net) for OIDC authorization code flow to get the access token for the API. The user authenticates e.g. with username and password to the API producer, then the user consents to API-usage by the API consumer. The authorization server uses whatever means (network authentication) it has to identify the subscription and "finds" the IMEI from the last network ATTACH for that subscription. Yes, the PPID is still personal identifiable information, but it is better than IMEI because the PPID can't be used for tracking the user by colluding API consumers. Please review https://github.com/AxelNennker/DeviceIdentifier/blob/pairwise/code/API_definitions/CAMARA%20Mobile%20Device%20Identifier%20API.yaml (not a PR yet). That Device Identifier API uses one endpoint and scopes to indicate what to retrieve e.g. ppid |
Beta Was this translation helpful? Give feedback.
-
@AxelNennker @eric-murray In a technical sense, both are possible (IMEI as device identifier, and a salted/hashed IMEI as PPID). In terms of privacy and legislation, there is another thing to consider besides the GDPR. We looked at it in more detail, and we think that in both cases the MNO is extracting information from a device. This falls under the ePrivacy directive in the EU, and as a consequence under the telecom laws of each of the EU countries. It is similar to cookies, as soon as you extract information from a device, you will need to acquire user consent (there is no legitimate interest construct in the ePrivacy Directive). This applies both to IMEI and PPID as identifiers, so this will be another bottleneck for many use cases. In terms of privacy, PPID is indeed better, but it really depends on the use case whether PPID can be used, and whether the devcie information needs to be shared between multple parties (for example a centralized black list of fraudulent devices). In that case IMEI would be simpler to work with. PPID would be an option as well, but then the MNO's woud need to act as middle man for the ASP to access a centralized black list of fraudulent IMEI numbers. The ASP knows in that case only the PPID, and the MNO stores the IMEI on request of the ASP in a centralized blacklist. |
Beta Was this translation helpful? Give feedback.
-
I'm happy to support returning a PPID as an additional option to the two existing options (IMEI and TAC) if there is an associated use case. We discussed before using scopes to control the output of a single endpoint, but rejected that in favour of separate endpoints. So introducing a PPID option would give us a third endpoint. The two defined endpoints are currently "mandatory" (i.e. there is no 501 response defined to avoid implementing either endpoint). We would need to decide if this third endpoint was mandatory or optional for implementation. Although the concept of generating a PPID from an IMEI is straightforward, implementation is not trivial. |
Beta Was this translation helpful? Give feedback.
-
There were various reasons why we decided to limit the endpoints to have a single scope, but one is that only a single scope is allowed by the current ICM guidelines:
At least this rule needs to be revised before we can re-consider multiple scopes being available for a single operation. |
Beta Was this translation helpful? Give feedback.
-
Every off-the-shelf OpenId provider does that. The complexity is low to non-existing.
200RetrieveIdentifier basically stays the same.
Using scopes is simpler. The current two endpoints are confusing because the API consumer can get every thing in "/retrieve-identifier" and a subset of the fields in "/retrieve-type". One endpoint returning one subset of attributes and the second using a different subset, seems quite random. The second endpoint "/retrieve-type" can be removed. Using scopes simplifies the API and every OpenId provider does this simple thing out-of-the-box. |
Beta Was this translation helpful? Give feedback.
-
I'm pretty sure that "off-the-shelf" OIDC implementations will not give me an implementation of the Device Identifier API. What they will do is allow me to retrieve a list of scopes associated with the access token, and pass that list to my micro-service implementation. But then my implementation needs to parse that scope list and construct the API response accordingly. That, by any definition, is an increase in complexity. If an endpoint only has a single scope defined for it, then the very fact that the API gateway has passed the request on to the micro-service means that the defined scope MUST have been associated with the access token. So the micro-service does not even have to check the scopes in that case. So single-scope endpoints are much simpler to implement. |
Beta Was this translation helpful? Give feedback.
-
But that's the point. OAS does not offer any way to capture scope dependent behaviour of an endpoint other than through documentation, which is imprecise at best, and of no help to code generators. If an endpoint is single scope, then it is clear that that scope offers access to the full capabilities of the endpoint. |
Beta Was this translation helpful? Give feedback.
-
It has been discussed several times in CAMARA, and the preference of API consumers (application developers) was for "atomic" APIs that do one thing, rather than "multi-purpose" APIs that can do several dependent on the parameters (including scopes) passed. In this case, there is not that much difference between the two existing endpoints, but they cover different use cases. An application developer is likely to be interested in one or other use case, which will determine which endpoint they use, and which scope they need the End User to agree to. Also, by splitting the use cases into different endpoints, it is easy for an API provider to remove endpoints they have not implemented. If there is an issue with not fully implementing a given YAML, then we will split into different files, but we do not need to do that yet. |
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
All reactions