5,606,722 Members 37,832 Now Online
XDA Developers Android and Mobile Development Forum

How to write to SMS Content Provider in Android KitKat WITHOUT being default SMS app

Tip us?
 
stepic
Old
#1  
stepic's Avatar
Senior Member - OP
Thanks Meter 22
Posts: 153
Join Date: Nov 2010
Location: Messina

 
DONATE TO ME
Default How to write to SMS Content Provider in Android KitKat WITHOUT being default SMS app

Hello,
we know that Google made huge changes on SMS management with the release of Android 4.4 KitKat.
In summary:
1) the user can choose a default SMS application and only this app can write to SMS content provider.
2) now there are two broadcast SMS_RECEIVED_ACTION (for all apps) and SMS_DELIVER_ACTION (only for the default app). You will get notified about an incoming SMS with both, but you cannot abort the broadcast anymore
If you want to delete (or to restore) an SMS, you have to become default app temporarily, annoying the user with two mandatory prompts.

Looking in Android sources we can find out that the default SMS app gets a special permission to write SMS with App Ops:

Code:
// Allow OP_WRITE_SMS for the newly configured default SMS app.
appOps.setMode(AppOpsManager.OP_WRITE_SMS, applicationData.mUid,
applicationData.mPackageName, AppOpsManager.MODE_ALLOWED);
and we also know that there is still a way to access App Ops in Android 4.4 KitKat:

From shell:
Code:
adb shell am start -a android.settings.SETTINGS -e ":android:show_fragment" "com.android.settings.applications.AppOpsSummary"
From your app:
Code:
Intent intent = new Intent(Intent.ACTION_MAIN);
ComponentName cn = new ComponentName("com.android.settings", "com.android.settings.Settings");
intent.setComponent(cn);
intent.putExtra(":android:show_fragment", "com.android.settings.applications.AppOpsSummary");
startActivity(intent);
If you go to Messaging tab and look into permissions, you will find out that your non-default SMS app has WRITE SMS OFF. But you can also turn that ON because it isn't mutually exclusive with the default app.
You still require user interaction (but not root) or root access to write this secure setting.
I hope that some developer can benefit of this before Google lock down definitively App Ops access. Sorry, but it doesn't solve abort broadcast issue.

I found this issue on AOSP: https://code.google.com/p/android/is...etail?id=61684
I also think that Google should change something with SMS. Why not let the user choose not one but more apps as "default" (like notification listener for example) and restore the ability to abort broadcast?

Best regards!
The Following 11 Users Say Thank You to stepic For This Useful Post: [ Click to Expand ]
 
Olangu
Old
#2  
Member
Thanks Meter 15
Posts: 61
Join Date: Oct 2011
This has stopped working in 4.4.2.

Do anyone have an work around?
 
Goliath27
Old
#3  
Goliath27's Avatar
Senior Member
Thanks Meter 17
Posts: 382
Join Date: Nov 2011
Location: Cleveland
Bump - need a way to fix the problem with SMS filtering. Numbers I've blocked with another app still get into my inbox defeating the purpose.

Sent from my i337 on Roids using xda premium
S4(i337 for ATT) on T-Mobile
Rom: depends on the day of the week
 
chico260
Old
#4  
chico260's Avatar
Senior Member
Thanks Meter 65
Posts: 204
Join Date: Nov 2013
Quote:
Originally Posted by Goliath27 View Post
Bump - need a way to fix the problem with SMS filtering. Numbers I've blocked with another app still get into my inbox defeating the purpose.

Sent from my i337 on Roids using xda premium
+1

Sent from my EVO using Tapatalk
Tags
app ops, sms
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes