অ্যান্ড্রয়েডের জন্য যেকোনো হোম এপিআই ব্যবহার করার আগে, অ্যাপটির ব্যবহারকারীর হোমে থাকা ডিভাইসগুলিতে অ্যাক্সেসের অনুমতি থাকতে হবে, যা API-তে কাঠামো হিসাবে উল্লেখ করা হয়েছে। Permissions API-এর মাধ্যমে, ব্যবহারকারী তাদের Google অ্যাকাউন্ট ব্যবহার করে হোম এপিআই অ্যাপগুলিকে তাদের বাড়ির ডিভাইসগুলিতে অ্যাক্সেস দিতে পারেন।
অনুমতি API ইন্টিগ্রেট করুন
চালিয়ে যাওয়ার আগে, নিশ্চিত করুন যে আপনি Android এ হোম চালু করেছেন। এই ধাপ থেকে homeManager ইনস্ট্যান্সটি এখানে সমস্ত অনুমতি উদাহরণে ব্যবহৃত হয়েছে।
প্রথমে, SDK-এর সাথে একটি ActivityResultCaller নিবন্ধন করুন। উদাহরণস্বরূপ, Sample App এটি কীভাবে পরিচালনা করে:
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
homeManager.registerActivityResultCallerForPermissions(this)
}
অনুমতি পরীক্ষা করুন
অনুমতির অনুরোধ করার আগে, আমরা আপনাকে অ্যাপের ব্যবহারকারী ইতিমধ্যেই কাঠামো অ্যাক্সেস করার জন্য সম্মতি দিয়েছেন কিনা তা পরীক্ষা করার পরামর্শ দিচ্ছি। এটি করার জন্য, Home ইনস্ট্যান্সের hasPermissions() পদ্ধতিতে কল করে PermissionsState মানগুলির একটি Flow পান:
val permissionsReadyState =
homeManager.hasPermissions().collect { state ->
when (state) {
PermissionsState.GRANTED -> println("Permissions granted, no need to request permissions")
PermissionsState.PERMISSIONS_STATE_UNAVAILABLE ->
println("Permissions state unavailable, request permissions")
PermissionsState.NOT_GRANTED ->
println("OAuth permission is enabled but not granted yet, request permissions")
PermissionsState.PERMISSIONS_STATE_UNINITIALIZED -> println(
"Permissions state is not initialized yet. Clients should wait for another status update"
)
else ->
throw IllegalStateException("""
HomeClient.hasPermissions state should be PermissionsState.GRANTED,
PermissionState.PERMISSIONS_STATE_UNINITIALIZED, or
PermissionsState.PERMISSIONS_STATE_UNAVAILABLE. Actual state: $state
""".trimIndent())
}
}
যদি চেকটি PermissionsState of NOT_GRANTED অথবা PERMISSIONS_STATE_UNAVAILABLE ফেরত দেয়, তাহলে এর অর্থ হল ব্যবহারকারী অথবা অ্যাপ্লিকেশনের স্ট্রাকচারে অ্যাক্সেস নেই। যদি চেকটি PermissionsState of GRANTED ফেরত দেয় কিন্তু পরবর্তী কল to structures() কোনও স্ট্রাকচার ফেরত দেয় না, তাহলে হয় ব্যবহারকারী Google Home app (GHA) সেটিংস পৃষ্ঠার মাধ্যমে অ্যাপটিতে অ্যাক্সেস প্রত্যাহার করেছেন, অথবা ব্যবহারকারীর প্রয়োজনীয় অ্যাক্সেস নেই।
অনুমতির জন্য অনুরোধ করুন
একটি নির্দিষ্ট কাঠামোর মধ্যে থাকা কাঠামো এবং ডিভাইসগুলিতে অ্যাক্সেস করার জন্য আপনার অ্যাপকে অনুমতি দিতে হবে।
যদি ব্যবহারকারী ইতিমধ্যেই অনুমতি না দিয়ে থাকেন, তাহলে Home ইনস্ট্যান্সের requestPermissions() পদ্ধতি ব্যবহার করে Permissions UI চালু করুন এবং ফলাফল প্রক্রিয়া করুন:
fun requestPermissions(scope: CoroutineScope, onShowSnackbar: (String) -> Unit) {
scope.launch {
val result =
try {
homeManager.requestPermissions()
} catch (e: HomeException) {
PermissionsResult(
PermissionsResultStatus.ERROR,
"Got HomeException with error: ${e.message}",
)
}
when (result.status) {
PermissionsResultStatus.SUCCESS -> {
Log.i(TAG, "Permissions successfully granted.")
}
PermissionsResultStatus.CANCELLED -> {
Log.i(TAG, "User cancelled Permissions flow.")
onShowSnackbar("User cancelled Permissions flow")
}
else -> {
Log.e(
TAG,
"Failed to grant permissions with error: ${result.status}, ${result.errorMessage}",
)
onShowSnackbar("Failed to grant permissions with error: ${result.errorMessage}")
}
}
}
}
Permissions UI সঠিকভাবে চালু করার জন্য, আপনার অ্যাপের জন্য ইতিমধ্যেই OAuth সেট আপ করা আবশ্যক।
অনুমতি দিন
এখন তুমি তোমার অ্যাপটি চালাতে পারবে এবং একজন ব্যবহারকারীর অনুমতি পেতে পারবে। কোন ধরণের ব্যবহারকারী অনুমতি দিতে পারবেন এবং কোন ধরণের ডিভাইসের জন্য অনুমতি দেওয়া যাবে, তা নির্ভর করবে তুমি Google Home Developer Console তোমার অ্যাপটি নিবন্ধিত করেছো কিনা তার উপর।
হোম এপিআই ব্যবহার করে অ্যাপ প্রকাশ করার জন্য Developer Console নিবন্ধন প্রয়োজন। হোম এপিআই পরীক্ষা এবং ব্যবহার করার জন্য এটির প্রয়োজন নেই।
যদি কোনও অ্যাপ Developer Console নিবন্ধিত না থাকে , তাহলে এটি যাচাই না করা অবস্থায় থাকবে। হোম API-এর ব্যবহারের পরীক্ষার জন্য এটি সুপারিশ করা হয়:
শুধুমাত্র OAuth কনসোলে পরীক্ষামূলক ব্যবহারকারী হিসেবে নিবন্ধিত ব্যবহারকারীরাই অ্যাপটির জন্য অনুমতি দিতে পারবেন। যাচাই না করা অ্যাপের জন্য ১০০ জন পরীক্ষামূলক ব্যবহারকারীর সীমা রয়েছে।
একটি যাচাই না করা অ্যাপের যেকোনো ডিভাইসের ধরণের ডিভাইসে অ্যাক্সেস থাকবে যা হোম API-এর জন্য OAuth দ্বারা সমর্থিত ( Developer Console ডিভাইসের ধরণের তালিকা)। একটি কাঠামোর সমস্ত ডিভাইস অনুমোদিত হবে।
যদি কোনও অ্যাপ Developer Console নিবন্ধিত থাকে এবং এক বা একাধিক ডিভাইস প্রকারের অ্যাক্সেসের জন্য অনুমোদিত হয়েছে, এবং OAuth এর জন্য ব্র্যান্ড যাচাইকরণ সম্পন্ন হয়েছে , এটি একটি যাচাইকৃত অবস্থায় থাকবে। উৎপাদনে একটি অ্যাপ চালু করার জন্য এই অবস্থা প্রয়োজন:
- পরীক্ষামূলক ব্যবহারকারীর সীমা আর প্রযোজ্য নয়। যেকোনো ব্যবহারকারী অ্যাপটিকে অনুমতি দিতে পারবেন।
- ব্যবহারকারী শুধুমাত্র Developer Console অনুমোদিত ডিভাইসের প্রকারগুলিকেই অনুমতি দিতে পারবেন।
এখন OAuth সেট আপ হয়ে গেছে, অ্যাপের requestPermissions() কল নিম্নলিখিত ডায়ালগগুলিকে ট্রিগার করে:
- ব্যবহারকারীকে তাদের ব্যবহার করা গুগল অ্যাকাউন্টটি নির্বাচন করতে বলা হবে।
- ব্যবহারকারীকে অ্যাপটিকে যে কাঠামোতে অ্যাক্সেস দিতে চান তা নির্বাচন করতে বলা হবে।
- একটি অযাচাইকৃত অ্যাপের জন্য, হোম এপিআই দ্বারা সমর্থিত সমস্ত ধরণের ডিভাইস অ্যাপটিতে উপলব্ধ।
- একটি যাচাইকৃত অ্যাপের জন্য, ব্যবহারকারী শুধুমাত্র Developer Console অনুমোদিত ডিভাইসের প্রকারগুলিকেই অনুমতি দিতে পারেন।
- সংবেদনশীল ডিভাইসের ধরণগুলির জন্য যেগুলি পরিচালনা করার অ্যাক্সেস অ্যাপের আছে, ব্যবহারকারী প্রতি ডিভাইসের ভিত্তিতে অ্যাক্সেস সীমাবদ্ধ করতে পারেন। উদাহরণস্বরূপ, যদি কোনও ব্যবহারকারীর তিনটি লক থাকে, তবে তারা কেবল সেই লকগুলির মধ্যে একটিতে অ্যাক্সেস দিতে পারে।
একবার অনুমতি দেওয়া হলে, অ্যাপটি হোম এপিআই ব্যবহার করে কাঠামোর ডিভাইসগুলির অবস্থা পড়তে এবং নিয়ন্ত্রণ করতে পারে। যদি ব্যবহারকারী কোনও নির্দিষ্ট ডিভাইসের ধরণ বা সংবেদনশীল ডিভাইসের জন্য অ্যাপটিকে অনুমতি না দেন, তাহলে অ্যাপটি হোম এপিআই ব্যবহার করে এটি অ্যাক্সেস, নিয়ন্ত্রণ বা স্বয়ংক্রিয় করতে পারবে না।
অনুমতি পরিবর্তন করুন
ভিন্ন কাঠামোর ডিভাইস অ্যাক্সেস করার অনুমতি দেওয়ার জন্য, অ্যাকাউন্ট পিকার চালু করা যেতে পারে যাতে ব্যবহারকারী Google অ্যাকাউন্ট এবং স্যুইচ করার জন্য কাঠামো বেছে নিতে পারেন। এই প্রক্রিয়া চলাকালীন, ব্যবহারকারীকে আবার সম্মতি স্ক্রিন দেখানো হবে, এমনকি যদি সম্মতি আগে দেওয়া হয়ে থাকে।
forceLaunch ফ্ল্যাগটি true তে সেট করে requestPermissions() আবার কল করে এটি করা যেতে পারে:
homeManager.requestPermissions(forceLaunch=true)
অনুমতি প্রত্যাহার করুন
ব্যবহারকারীরা পূর্বে মঞ্জুর করা অ্যাক্সেস প্রত্যাহার করতে পারেন:
Google MyAccounts পৃষ্ঠা > Data & privacy > Third-party apps & services এর মাধ্যমে। এটি প্রাথমিক সম্মতি মঞ্জুর করার সময় জারি করা OAuth টোকেনটি প্রত্যাহার করবে এবং ব্যবহারকারী সমস্ত পৃষ্ঠ (ফোন) এবং কাঠামো জুড়ে যে অ্যাপটি ব্যবহার করছিলেন তার যেকোনো উদাহরণে অ্যাক্সেস প্রত্যাহার করবে।
নিম্নলিখিত URL স্কিম ব্যবহার করে ব্যবহারকারীকে তৃতীয় পক্ষের অ্যাপস এবং পরিষেবা উপ-পৃষ্ঠায় একটি গভীর লিঙ্ক দিয়ে নির্দেশিত করা যেতে পারে:
https://myaccount.google.com/connections/link?project_number=Cloud project_numberGHA > সেটিংস > লিঙ্কড অ্যাপস পৃষ্ঠার মাধ্যমে। GHA তে ক্লিক করলে আপনাকে সেটিংস পৃষ্ঠায় নিয়ে যাওয়া হবে। সেখান থেকে, লিঙ্কড অ্যাপস টাইলে ক্লিক করুন যা আপনাকে সম্মতি স্ক্রিনের মতো দেখতে একটি পৃষ্ঠায় নিয়ে যাবে। এই পৃষ্ঠা থেকে ব্যবহারকারী অ্যাপের অ্যাক্সেস সরিয়ে ফেলতে পারবেন। ব্যবহারকারী এই একই পৃষ্ঠাটি ব্যবহার করে কোন ধরণের ডিভাইস বা নির্দিষ্ট সংবেদনশীল ডিভাইস অ্যাপে অ্যাক্সেসযোগ্য তা পরিবর্তন করতে পারবেন।
OkGoogle অনুমতি
okGoogle কমান্ডটি একটি ডিভাইস-স্তরের কমান্ড এবং এটি কাঠামোর যেকোনো ডিভাইস স্বয়ংক্রিয় করতে ব্যবহার করা যেতে পারে। তবে, একটি Home APIs অ্যাপের প্রতিটি ডিভাইসে অ্যাক্সেস নাও থাকতে পারে। নিম্নলিখিত টেবিলে বর্ণনা করা হয়েছে যে এই ধরনের ক্ষেত্রে অনুমতি কীভাবে প্রয়োগ করা হয়।
| অটোমেশন | বৈশিষ্ট্য | অনুমতি প্রয়োগ |
|---|---|---|
| রাত ১০:০০ টায়, শোবার ঘরের স্পিকারে "শোবার সময়" সম্প্রচার করুন। | ডিভাইসে AssistantBroadcastTrait । | অটোমেশন তৈরি :
|
| রাত ১০:০০ টায়, সমস্ত ডিভাইসে "শোবার সময়" সম্প্রচার করুন | AssistantBroadcastTrait বৈশিষ্ট্য। | অটোমেশন তৈরি :
|
| রাত ১০:০০ টায়, "কিছু গান বাজাও" | AssistantFulfillmentTrait.OkGoogleCommand | অটোমেশন তৈরি :
|
| যখনই কেউ বলে "কিছু গান বাজাও" | VoiceStarterTrait.OkGoogleEvent | অটোমেশন তৈরি :
|


