This library provides the BlockedNumbersInsert
API that allows you to create/insert blocked numbers.
An instance of the BlockedNumbersInsert
API is obtained by,
val insert = Contacts(context).blockedNumbers().insert()
Note that blocked number insertions will only work for privileged apps. For more info, read about Blocked numbers.
To create/insert a new blocked number,
val insertResult = Contacts(context)
.blockedNumbers()
.insert()
.blockedNumber { number = "(555) 555-5555" }
.commit()
If you need to insert multiple blocked numbers,
val newBlockedNumber1 = NewBlockedNumber(number = "(555) 555-5555")
val newBlockedNumber2 = NewBlockedNumber(number = "(123) 456-7890")
val insertResult = Contacts(context)
.blockedNumbers()
.insert()
.blockedNumbers(newBlockedNumber1, newBlockedNumber2)
.commit()
To execute the insert,
.commit()
The commit
function returns a Result
.
To check if all inserts succeeded,
val allInsertsSuccessful = insertResult.isSuccessful
To check if a particular insert succeeded,
val firstInsertSuccessful = insertResult.isSuccessful(newBlockedNumber1)
To get the BlockedNumber IDs of all the newly created BlockedNumbers,
val allBlockedNumberIds = insertResult.blockedNumberIds
To get the BlockedNumber ID of a particular BlockedNumber,
val secondBlockedNumberId = insertResult.blockedNumberId(newBlockedNumber2)
Once you have the BlockedNumber IDs, you can retrieve the newly created BlockedNumbers via the
BlockedNumbersQuery
API,
val blockedNumbers = contactsApi
.blockedNumbers()
.query()
.where { Id `in` allBlockedNumberIds }
.find()
ℹ️ For more info, read Query blocked numbers.
Alternatively, you may use the extensions provided in BlockedNumbersInsertResult
. To get all
newly created BlockedNumbers,
val blockedNumbers = insertResult.blockedNumbers(contactsApi)
To get a particular blockedNumber,
val blockedNumber = insertResult.blockedNumber(contactsApi, newBlockedNumber1)
The insert may fail for a particular blocked number for various reasons,
insertResult.failureReason(newBlockedNumber1)?.let {
when (it) {
NUMBER_ALREADY_BLOCKED -> tellUserTheNumberIsAlreadyBlocked()
NUMBER_IS_BLANK -> promptUserProvideANonBlankNumber()
UNKNOWN -> showGenericErrorMessage()
}
}
To cancel an insert amid execution,
.commit { returnTrueIfInsertShouldBeCancelled() }
The commit
function optionally takes in a function that, if it returns true, will cancel insert
processing as soon as possible. The function is called numerous times during insert processing to
check if processing should stop or continue. This gives you the option to cancel the insert.
For example, to automatically cancel the insert inside a Kotlin coroutine when the coroutine is cancelled,
launch {
withContext(coroutineContext) {
val insertResult = insert.commit { !isActive }
}
}
Inserts are executed when the commit
function is invoked. The work is done in the same thread as
the call-site. This may result in a choppy UI.
To perform the work in a different thread, use the Kotlin coroutine extensions provided in
the async
module. For more info,
read Execute work outside of the UI thread using coroutines.
You may, of course, use other multi-threading libraries or just do it yourself =)
ℹ️ Extensions for Kotlin Flow and RxJava are also in the project roadmap.
There are no permissions required for blocked numbers. However, there are privileges that must be acquired. For more info, read about Blocked numbers.