এই গাইডের বৈশিষ্ট্যগুলি নেটওয়ার্কিং এবং টেলিফোনি পরিচালনার ক্ষমতাগুলি বর্ণনা করে যা আপনি আপনার ডিভাইস পলিসি কন্ট্রোলার (DPC) অ্যাপে প্রয়োগ করতে পারেন। এই নথিতে কোড নমুনা রয়েছে এবং আপনি Android এর এন্টারপ্রাইজ বৈশিষ্ট্যগুলির জন্য নমুনা কোডের উত্স হিসাবে টেস্ট DPC অ্যাপটিও ব্যবহার করতে পারেন৷
একটি DPC অ্যাপ ব্যক্তিগত ডিভাইসে প্রোফাইল মালিক মোডে বা সম্পূর্ণরূপে পরিচালিত ডিভাইসে ডিভাইস মালিক মোডে চলতে পারে। এই টেবিলটি নির্দেশ করে যে কোন বৈশিষ্ট্যগুলি উপলব্ধ থাকে যখন DPC প্রোফাইল মালিক মোডে বা ডিভাইস মালিক মোডে চলে:
প্রোফাইল জুড়ে কাজের পরিচিতি অ্যাক্সেস করুন
EMM একটি ব্যবহারকারীর ব্যক্তিগত প্রোফাইলকে তাদের কাজের পরিচিতিগুলি অ্যাক্সেস করার অনুমতি দিতে পারে যাতে একজন ব্যবহারকারীর ব্যক্তিগত এবং কাজের পরিচিতিগুলি স্থানীয় অনুসন্ধান এবং দূরবর্তী ডিরেক্টরি সন্ধানের মাধ্যমে অ্যাক্সেসযোগ্য হয়৷ ব্যক্তিগত ডিভাইসে, ব্যক্তিগত প্রোফাইলে একটি একক ডায়ালার ব্যক্তিগত কলের পাশাপাশি কাজের কল করতে এবং গ্রহণ করতে পারে। উপরন্তু, কাজের পরিচিতিগুলি সিস্টেম UI-তে ভালভাবে একত্রিত হয়। যদি কাজের প্রোফাইলটি এনক্রিপ্ট করা থাকে, তবে এর ডেটা ব্যক্তিগত প্রোফাইলে পাওয়া যায় না।
সিস্টেম UI এর সাথে ইন্টিগ্রেটেড
সিস্টেম UI একটি ব্রিফকেস আইকন ব্যবহার করে ইনকামিং কাজের কল নির্দেশ করে। callLog ইনকামিং এবং আউটগোয়িং কাজের কল নির্ধারণ করার জন্য আইকনটিও দেখায়। ব্যক্তিগত ডায়ালার এবং পরিচিতি অ্যাপগুলি একটি দূরবর্তী ডিরেক্টরির সন্ধান ব্যবহার করে একটি কাজের পরিচিতির কলার আইডি তথ্য প্রদর্শন করতে পারে, তাই এটির প্রয়োজন নেই যে পরিচিতিটি ইতিমধ্যেই স্থানীয় ডিভাইসে সিঙ্ক করা আছে৷ মেসেজিং অ্যাপ স্থানীয় কলার আইডি এবং অনুসন্ধান করতে পারে।
অ্যান্ড্রয়েড কম্প্যাটিবিলিটি ডেফিনিশন ডকুমেন্ট (CDD) ডিফল্ট ডায়ালারে কাজের পরিচিতিগুলির জন্য প্রয়োজনীয়তাগুলি এবং প্রয়োজনীয়তাগুলিকে অন্তর্ভুক্ত করে যে পরিচিতিগুলি এবং মেসেজিং অ্যাপগুলিকে তারা কাজের প্রোফাইল থেকে এসেছে তা নির্দেশ করার জন্য ব্যাজ করা হয়েছে৷
কাজের পরিচিতিগুলি অ্যাক্সেসযোগ্য এবং অনুসন্ধানযোগ্য
ব্যবহারকারী তাদের ব্যক্তিগত প্রোফাইল থেকে কাজের পরিচিতিগুলি অ্যাক্সেস করতে এবং কল করতে পারে, যা ডায়ালার অ্যাপের অনুসন্ধান স্ক্রিনে প্রদর্শিত হয়। ব্যবহারকারী স্বয়ংসম্পূর্ণ ব্যবহার করে কাজের পরিচিতিগুলি অনুসন্ধান করতে পারেন যা ডিভাইসে স্থানীয়ভাবে সিঙ্ক করা হয় এবং একটি দূরবর্তী ডিরেক্টরি সন্ধানের মাধ্যমে তালিকাভুক্ত করা হয়৷
প্রাথমিক প্রোফাইলে কাজের পরিচিতিগুলি নিয়ন্ত্রণ করুন
ডিপিসি কাজের পরিচিতি অনুসন্ধানের অনুমতি নিয়ন্ত্রণ করে। প্রোফাইল মালিক মোডে চলমান, DPC ব্যক্তিগত প্রোফাইলে কাজের পরিচিতিগুলির দৃশ্যমানতা পরিচালনা করে। আরও তথ্যের জন্য, একটি ডিভাইস নীতি নিয়ন্ত্রক তৈরি করুন দেখুন।
ব্যক্তিগত প্রোফাইল দ্বারা কাজের পরিচিতিগুলি অনুসন্ধান করা ডিফল্টরূপে সক্ষম থাকে৷
নীতিটি কীভাবে সেট করা হয়েছে তা দেখতে,
DevicePolicyManager.getCrossProfileContactsSearchDisabled()ব্যবহার করুন।ব্যক্তিগত প্রোফাইল দ্বারা কাজের পরিচিতি অনুসন্ধান সক্ষম বা অক্ষম করতে,
DevicePolicyManager.setCrossProfileContactsSearchDisabled()ব্যবহার করুন।
কাজের ট্রাফিকের জন্য একটি নিরাপদ নেটওয়ার্ক সংযোগ নিশ্চিত করুন
একটি ডিভাইস মালিক মোড বা প্রোফাইল মালিক মোডে চলমান, একটি ডিভাইস নীতি নিয়ন্ত্রক একটি নির্দিষ্ট VPN অ্যাপের মাধ্যমে ট্রাফিক পাস করার জন্য অ্যাপ্লিকেশনগুলিকে বাধ্য করতে একটি সর্বদা-চালু ভার্চুয়াল প্রাইভেট নেটওয়ার্ক (VPN) সংযোগ ব্যবহার করতে পারে যা বাইপাস করা যায় না৷ একটি সর্বদা-চালু VPN সংযোগ ব্যবহার করে, DPC নিশ্চিত করতে পারে যে একটি কাজের প্রোফাইল বা পরিচালিত ডিভাইস থেকে নেটওয়ার্ক ট্র্যাফিক একটি VPN পরিষেবার মধ্য দিয়ে যায় এবং ব্যবহারকারীর হস্তক্ষেপ ছাড়াই৷ এই প্রক্রিয়াটি একটি কাজের প্রোফাইলের মধ্যে ক্রমাগত ট্র্যাফিকের জন্য একটি নিরাপদ নেটওয়ার্ক সংযোগ তৈরি করে৷
সর্বদা চালু ভিপিএন সংযোগ সম্পর্কে
সিস্টেম ফ্রেমওয়ার্কের অংশ হিসাবে, ভিপিএন রাউটিং স্বয়ংক্রিয়ভাবে পরিচালিত হয় যাতে ব্যবহারকারী ভিপিএন পরিষেবা বাইপাস করতে না পারে। লকডাউন মোডে থাকাকালীন ভিপিএন পরিষেবা সংযোগ বিচ্ছিন্ন হলে, ট্র্যাফিক খোলা ইন্টারনেটে লিক হতে পারে না৷ VpnService বাস্তবায়নকারী অ্যাপ্লিকেশনগুলির জন্য, সর্বদা-অন VPN একটি বিশ্বস্ত সার্ভারের মাধ্যমে একটি সুরক্ষিত VPN সংযোগ পরিচালনা করার এবং এটি বজায় রাখার জন্য একটি কাঠামো প্রদান করে। VPN পরিষেবা স্বয়ংক্রিয়ভাবে অ্যাপ আপডেট জুড়ে সংযোগটি পুনরায় চালু করে, সংযোগটি Wi-Fi বা সেলুলারের উপর থাকলে তা নির্বিশেষে। এবং ডিভাইস রিবুট হলে, ফ্রেমওয়ার্ক VPN সংযোগ পুনরায় চালু করে।
ভিপিএন পরিষেবার সংযোগ ব্যবহারকারীর কাছে স্বচ্ছ৷ একটি কোম্পানির মালিকানাধীন ডিভাইসের জন্য, ব্যবহারকারীকে সবসময়-অন মোডে একটি VPN-এর জন্য একটি সম্মতি ডায়ালগ নিশ্চিত করতে হবে না। ব্যবহারকারীর ভিপিএন নেটওয়ার্ক সেটিংস ম্যানুয়ালি একটি সর্বদা-অন-অন সংযোগ সক্ষম করার অনুমতি দেয়।
DISALLOW_CONFIG_VPN true হলে, ব্যবহারকারীকে VPN কনফিগার করা থেকে বাধা দেওয়া হয়। adb ডিবাগ কমান্ড ব্যবহার করে সর্বদা চালু VPN ওভাররাইড করা থেকে ব্যবহারকারীদের সীমাবদ্ধ করতে DISALLOW_DEBUGGING_FEATURES সক্ষম করুন৷ VPN আনইনস্টল করা থেকে ব্যবহারকারীকে আটকাতে, DevicePolicyManager.setUninstallBlocked কল করুন।
VPN পরিষেবা সেট আপ করুন
যে সংস্থা Android এর জন্য আপনার এন্টারপ্রাইজ সমাধান ব্যবহার করে VPN সেট আপ করে৷
- একটি VPN অ্যাপ ইনস্টল করুন যা
VpnServiceপ্রয়োগ করে।VpnService.SERVICE_INTERFACEএর সাথে মেলে এমন একটি ইন্টেন্ট ফিল্টার ব্যবহার করে আপনি সক্রিয় VPN পরিষেবাগুলি খুঁজে পেতে পারেন। -
BIND_VPN_SERVICEঅনুমতি দ্বারা সুরক্ষিত অ্যাপের ম্যানিফেস্টে একটিVpnServiceঘোষণা করুন। -
VpnServiceকনফিগার করুন যাতে এটি সিস্টেম দ্বারা শুরু হয়। একটি সিস্টেম বুট শুনে এবং নিজের জীবনচক্র নিয়ন্ত্রণ করে নিজেকে শুরু করতে VPN অ্যাপ সেট করা এড়িয়ে চলুন। - VPN অ্যাপের জন্য পরিচালিত কনফিগারেশন সেট করুন ( নীচের উদাহরণ দেখুন)।
সর্বদা-চালু VPN সংযোগ সক্ষম করুন৷
DevicePolicyManager.setAlwaysOnVpnPackage() এ কল করে DPC একটি নির্দিষ্ট অ্যাপের মাধ্যমে একটি সর্বদা-চালু VPN সংযোগ কনফিগার করতে পারে।
এই সংযোগটি স্বয়ংক্রিয়ভাবে মঞ্জুর করা হয় এবং রিবুট করার পরেও টিকে থাকে। যদি lockdownEnabled মিথ্যা হয়, তাহলে ফোন রিবুট এবং VPN সংযুক্ত হওয়ার সময় থেকে নেটওয়ার্ক ট্র্যাফিক অনিরাপদ হতে পারে৷ আপনি যদি VPN ব্যর্থ হলে নেটওয়ার্ক সংযোগ বন্ধ করতে না চান বা VPN অপরিহার্য না হলে এটি কার্যকর।
সর্বদা চালু ভিপিএন সংযোগ যাচাই করুন
ডিপিসি DevicePolicyManager.getAlwaysOnVpnPackage() .
যদি এমন কোনও প্যাকেজ না থাকে, বা সিস্টেম সেটিংস অ্যাপের মধ্যে VPN তৈরি করা হয়, null ফেরত দেওয়া হয়।
উদাহরণ
TestDPC অ্যাপে, AlwaysOnVpnFragment.java একটি সর্বদা চালু ভিপিএন সংযোগের জন্য সেটিং সক্ষম করতে এই APIগুলি ব্যবহার করে৷
নিম্নলিখিত উদাহরণে:
- VPN পরিষেবার পরিচালিত কনফিগারেশনগুলি
DevicePolicyManagerদ্বারা তারsetApplicationRestrictions()পদ্ধতি ব্যবহার করে সেট করা হয়। - পরিচালিত কনফিগারেশনগুলি নির্বিচারে কী-মানের জোড়া ব্যবহার করে এবং এই উদাহরণ অ্যাপটি VPN এর নেটওয়ার্ক সেটিংস কনফিগার করতে অন্য কোথাও ব্যবহার করে ( পরিচালিত কনফিগারেশনগুলি দেখুন )।
- উদাহরণটি একটি অস্বীকৃত তালিকায় অ্যান্ড্রয়েড প্যাকেজ ইনস্টলারকে যুক্ত করে যাতে এটি VPN এর মাধ্যমে সিস্টেম প্যাকেজগুলি আপডেট করে না। কাজের প্রোফাইল বা ডিভাইসের মধ্যে ব্যবহারকারীর সমস্ত নেটওয়ার্ক ট্র্যাফিক এই VPN অ্যাপের মাধ্যমে যায়, প্যাকেজ ইনস্টলার ছাড়া; এর আপডেটগুলি খোলা ইন্টারনেট ব্যবহার করে।
-
DevicePolicyManagerতারপরsetAlwaysOnVpnPackage()ব্যবহার করে VPN প্যাকেজের জন্য সর্বদা-চালু VPN সংযোগ সক্ষম করে এবং লকডাউন মোড সক্ষম করে৷
কোটলিন
// Set VPN's managed configurations val config = Bundle().apply { putString(Extras.VpnApp.ADDRESS, "192.0.2.0") putString(Extras.VpnApp.IDENTITY, "vpn.account1") putString(Extras.VpnApp.CERTIFICATE, "keystore://auth_certificate") putStringArray(Extras.VpnApp.DENYLIST, arrayOf("com.android.packageinstaller")) } val dpm = getSystemService(Context.DEVICE_POLICY_SERVICE) as DevicePolicyManager val admin = myDeviceAdminReceiver.getComponentName(this) // Name of package to update managed configurations val vpnPackageName = "com.example.vpnservice" // Associate managed configurations with DeviceAdminReceiver dpm.setApplicationRestrictions(admin, vpnPackageName, config) // Enable always-on VPN connection through VPN package try { val lockdownEnabled = true dpm.setAlwaysOnVpnPackage(admin, vpnPackageName, lockdownEnabled) } catch (ex: Exception) { throw PolicyException() }
জাভা
// Set VPN's managed configurations final Bundle config = new Bundle(); config.putString(Extras.VpnApp.ADDRESS, "192.0.2.0"); config.putString(Extras.VpnApp.IDENTITY, "vpn.account1"); config.putString(Extras.VpnApp.CERTIFICATE, "keystore://auth_certificate"); config.putStringArray(Extras.VpnApp.DENYLIST, new String[]{"com.android.packageinstaller"}); DevicePolicyManager dpm = (DevicePolicyManager) getSystemService(Context.DEVICE_POLICY_SERVICE); ComponentName admin = myDeviceAdminReceiver.getComponentName(this); // Name of package to update managed configurations final String vpnPackageName = "com.example.vpnservice"; // Associate managed configurations with DeviceAdminReceiver dpm.setApplicationRestrictions(admin, vpnPackageName, config); // Enable always-on VPN connection through VPN package try { boolean lockdownEnabled = true; dpm.setAlwaysOnVpnPackage(admin, vpnPackageName, lockdownEnabled)); } catch (Exception ex) { throw new PolicyException(...); }
অঞ্চল জুড়ে একটি একক ওয়্যারলেস নেটওয়ার্ক আইডি সেট আপ করুন৷
একটি ডিভাইস মালিক মোড বা প্রোফাইল মালিক মোডে চলমান, একটি ডিভাইস নীতি নিয়ন্ত্রক (DPC) একাধিক শংসাপত্র কর্তৃপক্ষ (CA) শংসাপত্রকে একটি একক ওয়্যারলেস নেটওয়ার্ক কনফিগারেশনের সাথে সংযুক্ত করতে পারে। এই কনফিগারেশনের মাধ্যমে, একটি ডিভাইস ওয়্যারলেস অ্যাক্সেস পয়েন্টগুলির সাথে সংযোগ করতে পারে যেগুলির একই নেটওয়ার্ক নাম, বা পরিষেবা সেট শনাক্তকারী (SSID), কিন্তু বিভিন্ন CA শংসাপত্রের সাথে কনফিগার করা হয়েছে৷ আপনার প্রতিষ্ঠানের ওয়্যারলেস নেটওয়ার্কগুলি একাধিক ভৌগলিক অঞ্চল জুড়ে অবস্থিত থাকলে এবং প্রতিটি অঞ্চলের জন্য একটি আলাদা শংসাপত্র কর্তৃপক্ষের প্রয়োজন হলে এটি কার্যকর। উদাহরণস্বরূপ, আইনি স্বাক্ষরের জন্য একটি স্থানীয় কর্তৃপক্ষের প্রয়োজন হতে পারে যার একটি আঞ্চলিক CA প্রয়োজন৷
দ্রষ্টব্য: অ্যান্ড্রয়েড API 18 (জেলি বিন) থেকে setCaCertificate সমর্থন করেছে, তবে আইটি প্রশাসকদের অবশ্যই প্রতিটি CA এর সাথে আলাদাভাবে তাদের নেটওয়ার্কের ব্যবস্থা করতে হবে যাতে ডিভাইসগুলি তাদের অঞ্চল নির্বিশেষে প্রতিটি অ্যাক্সেস পয়েন্টে নির্বিঘ্ন প্রমাণীকরণ করে।
সার্ভার সনাক্ত করতে CA শংসাপত্রগুলি নির্দিষ্ট করুন৷
X.509 সার্টিফিকেটের একটি তালিকা নির্দিষ্ট করতে যা একই SSID ব্যবহার করে সার্ভারকে শনাক্ত করে, WifiEnterpriseConfig.setCaCertificates() ব্যবহার করে বেতার কনফিগারেশনে সমস্ত প্রাসঙ্গিক CA অন্তর্ভুক্ত করুন।
একটি সার্ভারের শংসাপত্র বৈধ যদি এর CA প্রদত্ত শংসাপত্রগুলির একটির সাথে মেলে৷ ডিফল্ট নামগুলি স্বয়ংক্রিয়ভাবে শংসাপত্রগুলিতে বরাদ্দ করা হয় এবং কনফিগারেশনের মধ্যে ব্যবহৃত হয়। WifiManager শংসাপত্রটি ইনস্টল করে এবং নেটওয়ার্ক সক্রিয় থাকা অবস্থায় স্বয়ংক্রিয়ভাবে কনফিগারেশন সংরক্ষণ করে এবং কনফিগারেশন মুছে ফেলা হলে শংসাপত্রটি সরিয়ে দেয়।
ওয়্যারলেস কনফিগারেশনের সাথে যুক্ত সমস্ত CA সার্টিফিকেট পেতে, X509Certificate অবজেক্টের একটি তালিকা ফেরত দিতে WifiEnterpriseConfig.getCaCertificates() ব্যবহার করুন।
একাধিক CA শংসাপত্র ব্যবহার করে একটি বেতার কনফিগারেশন যোগ করুন
- সার্ভারের পরিচয় যাচাই করুন:
- X.509 CA সার্টিফিকেট লোড করুন।
- ক্লায়েন্টের ব্যক্তিগত কী এবং শংসাপত্র লোড করুন। একটি শংসাপত্র ফাইল কিভাবে পড়তে হয় তার উদাহরণের জন্য HTTPS এবং SSL এর সাথে নিরাপত্তা দেখুন।
- একটি নতুন
WifiConfigurationতৈরি করুন এবং এর SSID এবং কী ব্যবস্থাপনা সেট করুন। - এই
WifiConfigurationWifiEnterpriseConfigউদাহরণ সেট আপ করুন।-
setCaCertificates()ব্যবহার করেX509Certificateঅবজেক্টের তালিকা সহ সার্ভার সনাক্ত করুন। - ক্লায়েন্ট শংসাপত্র, পরিচয়, এবং পাসওয়ার্ড সেট করুন।
- সংযোগ স্থাপনের অংশ হিসাবে এক্সটেনসিবল অথেনটিকেশন প্রোটোকল (EAP) এবং ফেজ 2 পদ্ধতি সেট করুন।
-
-
WifiManagerদিয়ে নেটওয়ার্ক যোগ করুন। - নেটওয়ার্ক সক্রিয় করুন। WifiManager সেটআপের সময় স্বয়ংক্রিয়ভাবে কনফিগারেশন সংরক্ষণ করে।
এই উদাহরণটি ধাপগুলিকে একত্রিত করে:
কোটলিন
// Verify the server's identity val caCert0 = getCaCert("cert0.crt") val caCert1 = getCaCert("cert1.crt") val clientKey = getClientKey() val clientCert = getClientCert() // Create Wi-Fi configuration val wifiConfig = WifiConfiguration().apply { SSID = "mynetwork" allowedKeyManagement.set(KeyMgmt.WPA_EAP) allowedKeyManagement.set(KeyMgmt.IEEE8021X) // Set up Wi-Fi enterprise configuration enterpriseConfig.setCaCertificates(arrayOf<X509Certificate>(caCert0, caCert1)) enterpriseConfig.setClientKeyEntry(clientKey, clientCert) enterpriseConfig.setIdentity("myusername") enterpriseConfig.setEapMethod(Eap.TLS) enterpriseConfig.setPhase2Method(Phase2.NONE) } // Add network val wifiManager = getSystemService(Context.WIFI_SERVICE) as WifiManager val netId = wifiManager.addNetwork(wifiConfig) // Enable network if (netId < 0) { // Error creating new network } else { wifiManager.enableNetwork(netId, true) }
জাভা
// Verify the server's identity X509Certificate caCert0 = getCaCert("cert0.crt"); X509Certificate caCert1 = getCaCert("cert1.crt"); PrivateKey clientKey = getClientKey(); X509Certificate clientCert = getClientCert(); // Create Wi-Fi configuration WifiConfiguration wifiConfig = new WifiConfiguration(); wifiConfig.SSID = "mynetwork"; wifiConfig.allowedKeyManagement.set(KeyMgmt.WPA_EAP); wifiConfig.allowedKeyManagement.set(KeyMgmt.IEEE8021X); // Set up Wi-Fi enterprise configuration wifiConfig.enterpriseConfig.setCaCertificates(new X509Certificate[] {caCert0, caCert1}); wifiConfig.enterpriseConfig.setClientKeyEntry(clientKey, clientCert); wifiConfig.enterpriseConfig.setIdentity("myusername"); wifiConfig.enterpriseConfig.setEapMethod(Eap.TLS); wifiConfig.enterpriseConfig.setPhase2Method(Phase2.NONE); // Add network WifiManager wifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE); int netId = wifiManager.addNetwork(wifiConfig); // Enable network if (netId < 0) { // Error creating new network } else { wifiManager.enableNetwork(netId, true); }
কাজের প্রোফাইলের জন্য একটি পৃথক ডায়ালার উল্লেখ করুন
আপনি একটি কাজের প্রোফাইলে ব্যবহার করার জন্য একটি পৃথক ডায়লার অ্যাপ্লিকেশনের অনুমতি দিতে পারেন। এটি নিজেই ডায়ালার, অথবা একটি ভয়েস ওভার আইপি (VoIP) অ্যাপ হতে পারে যা কলিং ব্যাকএন্ডের জন্য ConnectionService API প্রয়োগ করে। এটি কাজের প্রোফাইলে ভিওআইপি অ্যাপ্লিকেশনগুলিতে একই সমন্বিত সিস্টেম UI ডায়ালিংয়ের অভিজ্ঞতা প্রদান করে, কার্যকরভাবে কাজের ডায়লারটিকে একটি মূল বৈশিষ্ট্য হিসাবে তৈরি করে৷ কাজের কলিং অ্যাকাউন্টে ইনকামিং কলগুলি ব্যক্তিগত কলিং অ্যাকাউন্টগুলিতে ইনকামিং কল থেকে আলাদা।
ব্যবহারকারী একটি ফোন অ্যাকাউন্টে অনুমোদিত তালিকাভুক্ত কাজের ডায়ালার থেকে কল করতে এবং গ্রহণ করতে পারেন। সেই ডায়ালার থেকে করা সমস্ত কল, বা কাজের ফোন অ্যাকাউন্টে ইনকামিং, কাজের প্রোফাইলের CallLog প্রদানকারীতে রেকর্ড করা হয়। কাজের ডায়ালার শুধুমাত্র কাজের পরিচিতিগুলিতে অ্যাক্সেস সহ একটি কাজের কল লগ বজায় রাখে। ইনকামিং সার্কিট-সুইচ কলগুলি প্রাথমিক ডায়লার দ্বারা পরিচালিত হয় এবং একটি ব্যক্তিগত কল লগে সংরক্ষণ করা হয়। যদি একটি কাজের প্রোফাইল মুছে ফেলা হয়, সেই কাজের প্রোফাইলের সাথে যুক্ত কল লগটিও মুছে ফেলা হয়, সমস্ত কাজের প্রোফাইল ডেটার সাথে।
থার্ড-পার্টি অ্যাপসকে অবশ্যই ConnectionService প্রয়োগ করতে হবে
থার্ড-পার্টি ভিওআইপি অ্যাপ্লিকেশানগুলি যেগুলিকে ফোন কল করতে হবে এবং সেই কলগুলিকে অন্তর্নির্মিত ফোন অ্যাপে একত্রিত করতে হবে তারা ConnectionService API প্রয়োগ করতে পারে৷ কাজের কলিংয়ের জন্য ব্যবহৃত যেকোন ভিওআইপি পরিষেবার জন্য এটি প্রয়োজনীয়। এই অ্যাপগুলি তাদের কলগুলিকে ঐতিহ্যবাহী সেলুলার কলের মতো বিবেচনা করে উপকৃত হয়, উদাহরণস্বরূপ, তারা বিল্ট-ইন সিস্টেম ডায়ালার এবং কল লগে দেখায়৷ যদি ConnectionService বাস্তবায়নকারী অ্যাপটি কাজের প্রোফাইলে ইনস্টল করা থাকে, তবে এটি শুধুমাত্র সেই কাজের প্রোফাইলে ইনস্টল করা ডায়ালার দ্বারা অ্যাক্সেসযোগ্য।
বিকাশকারী একবার ConnectionService প্রয়োগ করলে, তাদের উচিত অ্যাপের ম্যানিফেস্ট ফাইলে এটি যোগ করা এবং TelecomManager সাথে একটি PhoneAccount নিবন্ধন করা। একটি ফোন অ্যাকাউন্ট ফোন কল করার বা গ্রহণ করার জন্য একটি স্বতন্ত্র পদ্ধতির প্রতিনিধিত্ব করে এবং প্রতিটি ConnectionService জন্য একাধিক PhoneAccounts থাকতে পারে। ফোন অ্যাকাউন্ট নিবন্ধিত হওয়ার পরে, ব্যবহারকারী ডায়লার সেটিংসের মাধ্যমে এটি সক্ষম করতে পারেন।
সিস্টেম UI ইন্টিগ্রেশন এবং বিজ্ঞপ্তি
সিস্টেম UI ব্যবহারকারীদের থার্ড-পার্টি অ্যাপ্লিকেশানগুলির জন্য একটি সামঞ্জস্যপূর্ণ এবং সমন্বিত ডায়ালিংয়ের অভিজ্ঞতা প্রদান করে যা কল করার জন্য ব্যাকএন্ড হিসাবে ConnectionService API ব্যবহার করে। কাজের প্রোফাইলে অ্যাপ ব্যবহার করলে, ইনকামিং কলে এবং স্ট্যাটাস বারে একটি ব্রিফকেস আইকন প্রদর্শিত হয়। কাজের প্রোফাইলে ইনস্টল করা ConnectionService প্রয়োগ করে এমন একটি অ্যাপ সিস্টেম ডায়ালার ব্যবহার করতে পারে বা একটি পৃথক কাজের ডায়ালার তৈরি করতে পারে। এগুলি একটি একক অ্যাপ বা পৃথক অ্যাপ হতে পারে।
android.telecom.Call.Details.PROPERTY_ENTERPRISE_CALL ফ্ল্যাগ চেক করে ডায়ালার অ্যাপ্লিকেশনটি নির্ধারণ করে যে এটি একটি কাজের কল করছে বা গ্রহণ করছে। কলটি একটি কাজের কল হলে, ডায়ালারটি একটি কাজের ব্যাজ (ব্রিফকেস আইকন) যোগ করে ব্যবহারকারীকে এটি নির্দেশ করে:
কোটলিন
// Call placed through a work phone account. getCurrentCall() is defined by the // dialer. val call = getCurrentCall() if (call.hasProperty(android.telecom.Call.Details.PROPERTY_ENTERPRISE_CALL)) { // Set briefcase icon }
জাভা
// Call placed through a work phone account. getCurrentCall() is defined by the // dialer. Call call = getCurrentCall(); if (call.hasProperty(android.telecom.Call.Details.PROPERTY_ENTERPRISE_CALL)) { // Set briefcase icon }