Closed
Bug 887156
Opened 11 years ago
Closed 11 years ago
Define which MSISDNs can send wap push messages to user
Categories
(Firefox OS Graveyard :: RIL, defect)
Tracking
(blocking-b2g:koi+, firefox26 fixed)
People
(Reporter: kchang, Assigned: gsvelto)
References
Details
(Whiteboard: [ETA:8/9], [FT:RIL], [Sprint:2])
Attachments
(2 files, 5 obsolete files)
As an operator I want to define which MSISDNs can send wap push messages to user so the user is not spammed by adverts.
Two questions about the user story: 1. We have to support multiple MSISDNs, right? 2. Does the white list can be modified after shipping? This might be required if operator want to update the white list, or if we allow users to add white list of their own.
Flags: needinfo?(kchang)
Reporter | ||
Comment 2•11 years ago
|
||
(In reply to Chuck Lee [:chucklee] from comment #1) > Two questions about the user story: > 1. We have to support multiple MSISDNs, right? Need Bruce to answer. > 2. Does the white list can be modified after shipping? > This might be required if operator want to update the white list, or if > we allow users to add white list of their own. No, this is a customization. User can not change it in shipping device.
Flags: needinfo?(kchang) → needinfo?(bhuang)
(In reply to Ken Chang from comment #2) > (In reply to Chuck Lee [:chucklee] from comment #1) > > 2. Does the white list can be modified after shipping? > > This might be required if operator want to update the white list, or if > > we allow users to add white list of their own. > No, this is a customization. User can not change it in shipping device. I think we have to make sure operators don't have the request to change it as well. If they do, unless they are willing to modify gecko, we have to provide API for that, and we can't prevent user from writing app to do the same thing.
Comment 5•11 years ago
|
||
(In reply to Ken Chang from comment #2) > (In reply to Chuck Lee [:chucklee] from comment #1) > > Two questions about the user story: > > 1. We have to support multiple MSISDNs, right? > Need Bruce to answer. Yes, we should allow a list of MSISDNs.
Comment 6•11 years ago
|
||
(In reply to Chuck Lee [:chucklee] from comment #3) > (In reply to Ken Chang from comment #2) > > (In reply to Chuck Lee [:chucklee] from comment #1) > > > 2. Does the white list can be modified after shipping? > > > This might be required if operator want to update the white list, or if > > > we allow users to add white list of their own. > > No, this is a customization. User can not change it in shipping device. > > I think we have to make sure operators don't have the request to change it > as well. > If they do, unless they are willing to modify gecko, we have to provide API > for that, and we can't prevent user from writing app to do the same thing. Is there a way to do it so OTA provisioning can modify the field as well? Or can all customization be modified via user developed applications?
Flags: needinfo?(bhuang)
Summary: Define which MSISDNs can send wap push messages to user → [WAP Push][User Story] MSISDN filtering
(In reply to bhuang from comment #6) > Is there a way to do it so OTA provisioning can modify the field as well? > Or can all customization be modified via user developed applications? There's no specific parameter in CP for this usage. Modifying MSISDN filter can be done using settings, but I prefer we define a maximum number of MSISDN in white list.
I think of another method: put the filter in application instead of gecko. Since operator need to provide an app for handling WAP Push(because we don't support app), and the method of getting new MSISDN filter list should be operator-specific. It's straightforward for the operator to integrate filter and filter update mechanism into provided WAP Push app.
Summary: [WAP Push][User Story] MSISDN filtering → Define which MSISDNs can send wap push messages to user
Reporter | ||
Comment 9•11 years ago
|
||
(In reply to Chuck Lee [:chucklee] from comment #8) > I think of another method: put the filter in application instead of gecko. > > Since operator need to provide an app for handling WAP Push(because we don't > support app), and the method of getting new MSISDN filter list should be > operator-specific. It's straightforward for the operator to integrate filter > and filter update mechanism into provided WAP Push app. It makes sense to me. Gabriele, what do you think?
Flags: needinfo?(gsvelto)
Assignee | ||
Comment 10•11 years ago
|
||
I'm not very familiar with the WAP Push code yet so bear with me if I'm getting this wrong. To implement what's suggested in comment 8 we would need to adjust our API to expose the MSISDN for each push to content so a vendor-provided Gaia app will be able to filter the messages; is that correct? In this case we should restrict this API to certified apps otherwise another app might decide to receive all pushes and bypass the filtering. That being said if we go this way how would we handle the operator updating the whitelist? Should that be taken care of by the application too in a vendor-specific way? If that's the case then there wouldn't be much else to do for us expect from exposing the right API. We might still want to make a reference application as an example for vendors to develop their own.
Flags: needinfo?(gsvelto)
Assignee | ||
Comment 11•11 years ago
|
||
BTW there's been a discussion on dev-platform recently about having a generic system for delivering updates to files such as certificate lists, page white-lists and such. Depending on the way we want to go here it might be relevant to this effort: https://groups.google.com/d/msg/mozilla.dev.platform/p74X9iipfhg/MFeslNOteUAJ
(In reply to Gabriele Svelto [:gsvelto] from comment #10) > I'm not very familiar with the WAP Push code yet so bear with me if I'm > getting this wrong. > > To implement what's suggested in comment 8 we would need to adjust our API > to expose the MSISDN for each push to content so a vendor-provided Gaia app > will be able to filter the messages; is that correct? In this case we should > restrict this API to certified apps otherwise another app might decide to > receive all pushes and bypass the filtering. I think this can be done with a permission to wap push. If an app receives all wap push and becomes annoying, it can be prevented from receiving wap push by removing its permission. > That being said if we go this way how would we handle the operator updating > the whitelist? Should that be taken care of by the application too in a > vendor-specific way? > If that's the case then there wouldn't be much else to do for us expect from > exposing the right API. We might still want to make a reference application > as an example for vendors to develop their own. I have no reference on how vendors update their white list, but I didn't find any standard for doing that. So I assume this is vendor-specific function, vendors should implement it on their own. In such case, I think we can only provide a reference on how to filter based on MSISDN, but no reference on the update protocol.
Assignee | ||
Comment 13•11 years ago
|
||
(In reply to Chuck Lee [:chucklee] from comment #12) > I think this can be done with a permission to wap push. > If an app receives all wap push and becomes annoying, it can be prevented > from receiving wap push by removing its permission. OK, so you would like to have the API available also for non-certified apps? That means a user app might display all pushes including the ones not filtered by the app provided by the carrier. > So I assume this is vendor-specific function, vendors should implement it on > their own. > In such case, I think we can only provide a reference on how to filter based > on MSISDN, but no reference on the update protocol. Agreed.
(In reply to Gabriele Svelto [:gsvelto] from comment #13) > OK, so you would like to have the API available also for non-certified apps? Yes, I think it's what these APIs(only a system message for WAP Push, actually) are designed for. Normal developers can build apps doing whatever they intent to, it's up to users to install that app or not. > That means a user app might display all pushes including the ones not > filtered by the app provided by the carrier. There might be a user app showing all messages, but might also be a user app providing filter. For those are interested in WAP Push message, or those who's phones doesn't have carrier provided app, user app is the only way of accessing WAP Push messages.
Updated•11 years ago
|
blocking-b2g: --- → koi+
Updated•11 years ago
|
Whiteboard: [ETA:8/9]
Depends on: 899442
Depends on: 900331
Updated•11 years ago
|
Whiteboard: [ETA:8/9] → [ETA:8/9], [FT:RIL], [Sprint:2]
Reporter | ||
Comment 15•11 years ago
|
||
Gabriele, do you have any concern to implement this function in Gaia? If not, I will assign this bug to you.
Flags: needinfo?(gsvelto)
Assignee | ||
Comment 16•11 years ago
|
||
(In reply to Ken Chang from comment #15) > Gabriele, do you have any concern to implement this function in Gaia? If > not, I will assign this bug to you. I haven't and in fact after discussing with :vingtetun I was already considering of developing an app to handle WAP Push messages in bug 891762 so it would be straightforward to add the filtering code to it. The only problem is that the current API delivers all the messages irrespective of the MSISDN which sent them and there's no way in Gaia to discover from which MSISDN a messages was sent from. So we need at least a bit of functionality to expose the MSISDN to Gaia in order to be able to implement this. Do you know who was responsible for the platform WAP Push code? I can add the extra platform functionality myself if need be but it will take me a little bit more time obviously.
Flags: needinfo?(gsvelto)
(In reply to Gabriele Svelto [:gsvelto] from comment #16) > The only problem is that the current API delivers all the messages > irrespective of the MSISDN which sent them and there's no way in Gaia to > discover from which MSISDN a messages was sent from. So we need at least a > bit of functionality to expose the MSISDN to Gaia in order to be able to > implement this. I am doing it in bug 900331. MSISDN will be carried as 'sender' in system message.
Assignee | ||
Comment 18•11 years ago
|
||
(In reply to Chuck Lee [:chucklee] from comment #17) > (In reply to Gabriele Svelto [:gsvelto] from comment #16) > I am doing it in bug 900331. > MSISDN will be carried as 'sender' in system message. Great, thanks for the feedback and sorry for not spotting it earlier.
Reporter | ||
Comment 19•11 years ago
|
||
According to comment 18, we only need the Gaia's fix for this bug. Assign to Gabriele.
Assignee: chulee → gsvelto
Assignee | ||
Comment 20•11 years ago
|
||
This patch adds the whitelisting mechanism directly into the application as discussed in this bug. A vendor customizing it would only need to add the MSISDNs to whitelist to the apps/wappush/js/whitelist.json file as entries in a JSON array.
Attachment #797892 -
Flags: review?(timdream)
Comment 21•11 years ago
|
||
Comment on attachment 797892 [details] [diff] [review] [PATCH] Add a mechanism to filter WAP Push messages based on a whitelist of source MSISDNs Review of attachment 797892 [details] [diff] [review]: ----------------------------------------------------------------- The code looks good. However you would need to put /js/whitelist.json to ./apps/wappush/.gitignore and have it generated from the (in)famous ./build/applications-data.js.
Attachment #797892 -
Flags: review?(timdream) → feedback+
Assignee | ||
Comment 22•11 years ago
|
||
(In reply to Tim Guan-tin Chien [:timdream] (MoCo-TPE) from comment #21) > The code looks good. However you would need to put /js/whitelist.json to > ./apps/wappush/.gitignore and have it generated from the (in)famous > ./build/applications-data.js. I've updated the patch with this change and rebased it on top of the changes in bug 887157. The rest of the code is identical and I've tested it on the emulator.
Attachment #797892 -
Attachment is obsolete: true
Attachment #801577 -
Flags: review?(timdream)
Updated•11 years ago
|
Component: DOM: Device Interfaces → RIL
Product: Core → Boot2Gecko
Assignee | ||
Updated•11 years ago
|
Status: NEW → ASSIGNED
Assignee | ||
Comment 23•11 years ago
|
||
Pointer to Github pull-request
Assignee | ||
Updated•11 years ago
|
Attachment #802382 -
Attachment description: Pointer to Github pull request: https://github.com/mozilla-b2g/gaia/pull/11864 → [PULL REQUEST] Add a mechanism to filter WAP Push messages based on a whitelist of source MSISDNs
Assignee | ||
Comment 24•11 years ago
|
||
This is the same patch as before but rebased on the latest changes and with the logic to filter out messages refactored into a separate function.
Attachment #801577 -
Attachment is obsolete: true
Attachment #801577 -
Flags: review?(timdream)
Attachment #802887 -
Flags: review?(timdream)
Comment 25•11 years ago
|
||
Comment on attachment 802887 [details] [diff] [review] [PATCH v3] Add a mechanism to filter WAP Push messages based on a whitelist of source MSISDNs Create a new file at |./apps/wappush/.gitignore| and use that. We should split app gitignores.
Attachment #802887 -
Flags: review?(timdream) → review+
Assignee | ||
Comment 26•11 years ago
|
||
(In reply to Tim Guan-tin Chien [:timdream] (MoCo-TPE) from comment #25) > Create a new file at |./apps/wappush/.gitignore| and use that. > We should split app gitignores. Thanks for the review! This is an updated patch with the .gitignore entry moved into apps/wappush/.gitignore; I'll merge it right away.
Attachment #802887 -
Attachment is obsolete: true
Assignee | ||
Comment 27•11 years ago
|
||
Merged in master: https://github.com/mozilla-b2g/gaia/commit/a7f11d14d1fa7988fa429fa87572e0072bf3c1a1
Status: ASSIGNED → RESOLVED
Closed: 11 years ago
Resolution: --- → FIXED
Comment 28•11 years ago
|
||
Please fix this linter error. ----- FILE : /home/travis/build/mozilla-b2g/gaia/apps/wappush/js/wappush.js ----- Line 78, E:0001: Extra space before ":"
Assignee | ||
Comment 29•11 years ago
|
||
(In reply to Anthony Ricaud (:rik) from comment #28) > Please fix this linter error. > ----- FILE : /home/travis/build/mozilla-b2g/gaia/apps/wappush/js/wappush.js > ----- > Line 78, E:0001: Extra space before ":" Awww... I remember having fixed it but I must have forgot to amend my commit. What's the less disruptive way of doing this? I've got more patches coming for this code so I can fold it in one of those instead of doing another patch here.
Comment 30•11 years ago
|
||
The sooner the linter is fixed, the happier I'll be :) You can do an extra commit and put it in this bug.
Comment 31•11 years ago
|
||
backed out: https://github.com/mozilla-b2g/gaia/commit/67673ba6ca70e3e30f03e6f95b5115d415cf8463 Please check travis... linter errors are the easiest to check its obvious that the travis output was not looked at.
Status: RESOLVED → REOPENED
Resolution: FIXED → ---
Assignee | ||
Comment 32•11 years ago
|
||
(In reply to James Lal [:lightsofapollo] from comment #31) > Please check travis... linter errors are the easiest to check its obvious > that the travis output was not looked at. Actually I ran the linter locally but forgot to update the PR :-/ Travis was failing all day long on intermittent errors so I must have not paid attention, sorry for that. Updated PR coming.
Assignee | ||
Comment 33•11 years ago
|
||
Pointer to Github pull-request
Assignee | ||
Updated•11 years ago
|
Attachment #803551 -
Attachment description: Pointer to Github pull request: https://github.com/mozilla-b2g/gaia/pull/12147 → [PULL REQUEST] Add a mechanism to filter WAP Push messages based on a whitelist of source MSISDNs
Assignee | ||
Updated•11 years ago
|
Attachment #802382 -
Attachment is obsolete: true
Assignee | ||
Comment 34•11 years ago
|
||
Fixed the extra whitespace, will be merging the updated PR soon.
Attachment #802956 -
Attachment is obsolete: true
Assignee | ||
Comment 35•11 years ago
|
||
Merged to master again: https://github.com/mozilla-b2g/gaia/commit/fe406c36bc28b2b33c9c08bcccf937137a643436
Status: REOPENED → RESOLVED
Closed: 11 years ago → 11 years ago
Resolution: --- → FIXED
Comment 36•11 years ago
|
||
Verify on following buid Gaia: e58cfdac65fe644dc79fb3613fdaa9d9573537ac1378985810 Build: 20130912134644 Wap push from numbers in whitelist.json (ex:["+47xxxxxxxx"]) can be displayed by wap push message app.
Status: RESOLVED → VERIFIED
Updated•11 years ago
|
status-firefox26:
--- → fixed
You need to log in
before you can comment on or make changes to this bug.
Description
•