উন্নততর নিরাপত্তা প্রদানের জন্য, কিছু ডিভাইসে একটি এমবেডেড সিকিওর এলিমেন্ট (SE) থাকে, যা ক্রিপ্টোগ্রাফিক ডেটা সংরক্ষণের জন্য একটি বিশেষায়িত, পৃথক এবং টেম্পার-প্রতিরোধী হার্ডওয়্যার। ওপেন মোবাইল এপিআই (Open Mobile API) হলো একটি স্ট্যান্ডার্ড এপিআই যা ডিভাইসের সিকিওর এলিমেন্টের সাথে যোগাযোগের জন্য ব্যবহৃত হয়। অ্যান্ড্রয়েড ৯ এই এপিআই-এর জন্য সাপোর্ট চালু করেছে এবং সিকিওর এলিমেন্ট সার্ভিস ও এসই এইচএএল (SE HAL) সহ একটি ব্যাকএন্ড ইমপ্লিমেন্টেশন প্রদান করে।
সিকিওর এলিমেন্ট সার্ভিস গ্লোবাল প্ল্যাটফর্ম-সমর্থিত সিকিওর এলিমেন্টগুলোর জন্য সমর্থন পরীক্ষা করে (মূলত এটি দেখে যে ডিভাইসগুলোতে SE HAL ইমপ্লিমেন্টেশন আছে কিনা এবং যদি থাকে, তবে কতগুলো)। এটি এপিআই এবং অন্তর্নিহিত সিকিওর এলিমেন্ট ইমপ্লিমেন্টেশন পরীক্ষা করার ভিত্তি হিসেবে ব্যবহৃত হয়।
ওপেন মোবাইল এপিআই টেস্ট কেস
ওপেন মোবাইল এপিআই (OMAPI) টেস্ট কেসগুলো এপিআই নির্দেশিকা প্রয়োগ করতে এবং সিকিওর এলিমেন্টের অন্তর্নিহিত বাস্তবায়ন ওপেন মোবাইল এপিআই স্পেসিফিকেশন পূরণ করে কিনা তা নিশ্চিত করতে ব্যবহৃত হয়। এই টেস্ট কেসগুলোর জন্য সিকিওর এলিমেন্টে একটি বিশেষ অ্যাপলেট—একটি জাভা কার্ড অ্যাপ্লিকেশন—ইনস্টল করা প্রয়োজন, যা CTS অ্যাপ্লিকেশনটি যোগাযোগের জন্য ব্যবহার করে। ইনস্টলেশনের জন্য, google-cardlet.cap এ থাকা নমুনা অ্যাপলেটটি ব্যবহার করুন।
OMAPI টেস্ট কেসগুলি পাস করার জন্য, অন্তর্নিহিত সিকিওর এলিমেন্ট সার্ভিস এবং SE-এর নিম্নলিখিত সক্ষমতা থাকা উচিত:
- সকল সিকিউর এলিমেন্ট রিডার-এর নাম SIM, eSE, বা SD দিয়ে শুরু হওয়া উচিত।
- সিম-বিহীন রিডারগুলো মৌলিক চ্যানেল খুলতে সক্ষম হওয়া উচিত।
-
CtsOmapiTestCases.apkপক্ষে A000000476416E64726F6964435453FF AID-টি নির্বাচন করা সম্ভব হওয়া উচিত নয়: -
CtsOmapiTestCases.apkনিম্নলিখিত অ্যাপ্লিকেশন আইডেন্টিফায়ার (AID) সহ একটি অ্যাপলেট নির্বাচন করতে সক্ষম হওয়া উচিত:- 0xA000000476416E64726F696443545331
-
android.se.omapi.Channel.Transmit( Transmit ) -এ নিম্নলিখিত অ্যাপ্লিকেশন প্রোটোকল ডেটা ইউনিট (APDUs) গ্রহণ করার সময় অ্যাপলেটটির একটি সিকিউরিটি এক্সেপশন (Security Exception) থ্রো করা উচিত:- ০x০০৭০০০০০
- ০x০০৭০৮০০০
- 0x00A40404104A535231373754657374657220312E30
- ট্রান্সমিট- এ নিম্নলিখিত APDU-গুলি গ্রহণ করলে অ্যাপলেটটির কোনো ডেটা ফেরত দেওয়া উচিত নয়:
- ০x০০০৬০০০০
- ০x৮০০৬০০০০
- 0xA0060000
- ০x৯৪০০৬০০০০
- 0x000A000001AA
- 0x800A000001AA
- 0xA00A000001AA
- 0x940A000001AA
- অ্যাপলেটটি নিম্নলিখিত ট্রান্সমিট এপিডিইউগুলোর জন্য ২৫৬-বাইট ডেটা ফেরত দেবে:
- ০x০০৮০০০০০০
- 0x8008000000
- 0xA008000000
- 0x9408000000
- 0x000C000001AA00
- 0x800C000001AA00
- 0xA00C000001AA00
- 0x940C000001AA00
- অ্যাপলেটটি সংশ্লিষ্ট ট্রান্সমিট APDU-এর জন্য নিম্নলিখিত স্ট্যাটাস ওয়ার্ড প্রতিক্রিয়াগুলি ফেরত দেবে:
প্রতিক্রিয়াটিতে ইনপুট APDU-এর অনুরূপ ডেটা থাকবে, তবে প্রথম বাইটটি 0x00-এর পরিবর্তে 0x01 হবে।APDU প্রেরণ করুন স্ট্যাটাস শব্দ ডেটা 0x00F30106 ০x৬২০০ না 0x00F30206 ০x৬২৮১ না 0x00F30306 ০x৬২৮২ না 0x00F30406 ০x৬২৮৩ না 0x00F30506 ০x৬২৮৫ না 0x00F30606 0x62F1 না 0x00F30706 ০x৬২এফ২ না 0x00F30806 0x63F1 না 0x00F30906 ০x৬৩এফ২ না 0x00F30A06 ০x৬৩সি২ না 0x00F30B06 ০x৬২০২ না 0x00F30C06 ০x৬২৮০ না 0x00F30D06 ০x৬২৮৪ না 0x00F30E06 ০x৬২৮৬ না 0x00F30F06 ০x৬৩০০ না 0x00F31006 ০x৬৩৮১ না 0x00F3010A01AA ০x৬২০০ না 0x00F3020A01AA ০x৬২৮১ না 0x00F3030A01AA ০x৬২৮২ না 0x00F3040A01AA ০x৬২৮৩ না 0x00F3050A01AA ০x৬২৮৫ না 0x00F3060A01AA 0x62F1 না 0x00F3070A01AA ০x৬২এফ২ না 0x00F3080A01AA 0x63F1 না 0x00F3090A01AA ০x৬৩এফ২ না 0x00F30A0A01AA ০x৬৩সি২ না 0x00F30B0A01AA ০x৬২০২ না 0x00F30C0A01AA ০x৬২৮০ না 0x00F30D0A01AA ০x৬২৮৪ না 0x00F30E0A01AA ০x৬২৮৬ না 0x00F30F0A01AA ০x৬৩০০ না 0x00F3100A01AA ০x৬৩৮১ না 0x00F3010800 ০x৬২০০ হ্যাঁ 0x00F3020800 ০x৬২৮১ হ্যাঁ 0x00F3030800 ০x৬২৮২ হ্যাঁ 0x00F3040800 ০x৬২৮৩ হ্যাঁ 0x00F3050800 ০x৬২৮৫ হ্যাঁ 0x00F3060800 0x62F1 হ্যাঁ 0x00F3070800 ০x৬২এফ২ হ্যাঁ 0x00F3080800 0x63F1 হ্যাঁ 0x00F3090800 ০x৬৩এফ২ হ্যাঁ 0x00F30A0800 ০x৬৩সি২ হ্যাঁ 0x00F30B0800 ০x৬২০২ হ্যাঁ 0x00F30C0800 ০x৬২৮০ হ্যাঁ 0x00F30D0800 ০x৬২৮৪ হ্যাঁ 0x00F30E0800 ০x৬২৮৬ হ্যাঁ 0x00F30F0800 ০x৬৩০০ হ্যাঁ 0x00F3100800 ০x৬৩৮১ হ্যাঁ 0x00F3010C01AA00 ০x৬২০০ হ্যাঁ* 0x00F3020C01AA00 ০x৬২৮১ হ্যাঁ* 0x00F3030C01AA00 ০x৬২৮২ হ্যাঁ* 0x00F3040C01AA00 ০x৬২৮৩ হ্যাঁ* 0x00F3050C01AA00 ০x৬২৮৫ হ্যাঁ* 0x00F3060C01AA00 0x62F1 হ্যাঁ* 0x00F3070C01AA00 ০x৬২এফ২ হ্যাঁ* 0x00F3080C01AA00 0x63F1 হ্যাঁ* 0x00F3090C01AA00 ০x৬৩এফ২ হ্যাঁ* 0x00F30A0C01AA00 ০x৬৩সি২ হ্যাঁ* 0x00F30B0C01AA00 ০x৬২০২ হ্যাঁ* 0x00F30C0C01AA00 ০x৬২৮০ হ্যাঁ* 0x00F30D0C01AA00 ০x৬২৮৪ হ্যাঁ* 0x00F30E0C01AA00 ০x৬২৮৬ হ্যাঁ* 0x00F30F0C01AA00 ০x৬৩০০ হ্যাঁ* 0x00F3100C01AA00 ০x৬৩৮১ হ্যাঁ* - অ্যাপলেটটির শেষ ডেটা বাইট হিসেবে
0xFFসহ খণ্ডিত প্রতিক্রিয়া ফেরত দেওয়া উচিত এবং এতে পরবর্তী APDU-গুলোর জন্য সংশ্লিষ্ট স্ট্যাটাস ওয়ার্ড ও প্রতিক্রিয়ার দৈর্ঘ্য থাকা উচিত।এপিডিইউ স্ট্যাটাস শব্দ প্রতিক্রিয়ার দৈর্ঘ্য (বাইট) 0x00C2080000 ০x৯০০০ ২০৪৮ 0x00C4080002123400 ০x৯০০০ ২০৪৮ 0x00C6080000 ০x৯০০০ ২০৪৮ 0x00C8080002123400 ০x৯০০০ ২০৪৮ 0x00C27FFF00 ০x৯০০০ ৩২৭৬৭ 0x00CF080000 ০x৯০০০ ২০৪৮ 0x94C2080000 ০x৯০০০ ২০৪৮ - অ্যাপলেটটি প্রদত্ত APDU: 0x00F4000000-এর জন্য SELECT কমান্ডে প্রাপ্ত P2-এর মান এবং সফলতার স্ট্যাটাস ওয়ার্ড (যেমন
0x009000) ফেরত দেবে।
-
- A000000476416E64726F696443545332
- নির্বাচিত হলে, এই AID-টির ২ বাইটের বেশি একটি সিলেক্ট রেসপন্স ফেরত দেওয়া উচিত, যা বেসিক এনকোডিং রুলস (BER) এবং ট্যাগ-লেংথ-ভ্যালু (TLV) ব্যবহার করে সঠিকভাবে ফরম্যাট করা থাকবে।
- 0xA000000476416E64726F696443545331
CtsOmapiTestCases
- এপিকে-এর হ্যাশ: 0x5cc49e0bc83927486fbb3a17ed37276cbbceb290
অ্যাক্সেস কন্ট্রোল টেস্ট কেস
সিকিওর এলিমেন্টে কনফিগার করা অ্যাক্সেস কন্ট্রোল নিশ্চিত করে যে, শুধুমাত্র যে অ্যাপ্লিকেশনের একটি অ্যাপলেটে অ্যাক্সেস আছে, সেটিই সেটির সাথে যোগাযোগ করতে পারবে। এছাড়াও, অ্যান্ড্রয়েড নির্দিষ্ট APDU-গুলির জন্য নিয়ম কনফিগার করা সমর্থন করে, যা APK দ্বারা আদান-প্রদান করা যেতে পারে।
এই পরীক্ষাগুলিতে উত্তীর্ণ হতে, বিশেষ অ্যাক্সেস কন্ট্রোল নিয়মগুলি কনফিগার করুন, যেমন অ্যাক্সেস রুল অ্যাপ্লিকেশন মাস্টার (ARA) অথবা অ্যাক্সেস রুল ফাইল (ARF)। আপনার সেই অ্যাপলেটটি ব্যবহার করা উচিত যা OMAPI পরীক্ষার জন্য ব্যবহৃত হয়, কারণ অ্যাক্সেস কন্ট্রোল পরীক্ষাগুলিতে উত্তীর্ণ হওয়ার জন্য একই কমান্ডগুলি সমর্থিত হতে হবে।
এই AID-গুলোর অধীনে অ্যাপলেটটির একটি ইনস্ট্যান্স তৈরি করুন:
- 0xA000000476416E64726F696443545340
- 0xA000000476416E64726F696443545341
- 0xA000000476416E64726F696443545342
- 0xA000000476416E64726F696443545343
- 0xA000000476416E64726F696443545344
- 0xA000000476416E64726F696443545345
- 0xA000000476416E64726F696443545346
- 0xA000000476416E64726F696443545347
- 0xA000000476416E64726F696443545348
- 0xA000000476416E64726F696443545349
- 0xA000000476416E64726F69644354534A
- 0xA000000476416E64726F69644354534B
- 0xA000000476416E64726F69644354534C
- 0xA000000476416E64726F69644354534D
- 0xA000000476416E64726F69644354534E
- 0xA000000476416E64726F69644354534F
নির্বাচিত হলে, এই AID-গুলোর যেকোনো একটির ফলে ২ বাইটের বেশি আকারের একটি সিলেক্ট রেসপন্স ফেরত আসা উচিত, যা BER এবং TLV ব্যবহার করে সঠিকভাবে ফরম্যাট করা থাকবে।
CtsSecureElementAccessControlTestCases1
- এপিকে-এর হ্যাশ: 0x4bbe31beb2f753cfe71ec6bf112548687bb6c34e
অনুমোদিত এইডস
0xA000000476416E64726F696443545340
অনুমোদিত এপিডিইউ:
- ০x০০০৬০০০০
- 0xA0060000
অননুমোদিত APDU:
- ০x০০৮০০০০০০
- ০x৮০০৬০০০০
- 0xA008000000
- 0x9406000000
0xA000000476416E64726F696443545341
অনুমোদিত এপিডিইউ:
- ০x৯৪০০৬০০০০
- 0x9408000000
- 0x940C000001AA00
- 0x940A000001AA
অননুমোদিত APDU:
- ০x০০০৬০০০০
- ০x৮০০৬০০০০
- 0xA0060000
- ০x০০৮০০০০০০
- 0x000A000001AA
- 0x800A000001AA
- 0xA00A000001AA
- 0x8008000000
- 0xA008000000
- 0x000C0000001AA00
- 0x800C000001AA00
- 0xA00C000001AA00
0xA000000476416E64726F696443545342
0xA000000476416E64726F696443545344
0xA000000476416E64726F696443545345
0xA000000476416E64726F696443545347
0xA000000476416E64726F696443545348
0xA000000476416E64726F696443545349
0xA000000476416E64726F69644354534A
0xA000000476416E64726F69644354534B
0xA000000476416E64726F69644354534C
0xA000000476416E64726F69644354534D
0xA000000476416E64726F69644354534E
0xA000000476416E64726F69644354534F
অননুমোদিত এইডস
- 0xA000000476416E64726F696443545343
- 0xA000000476416E64726F696443545346
CtsSecureElementAccessControlTestCases2
- এপিকে-এর হ্যাশ: 0x93b0ff2260babd4c2a92c68aaa0039dc514d8a33
অনুমোদিত এইডসমূহ:
0xA000000476416E64726F696443545340
অনুমোদিত এপিডিইউ:
- ০x০০০৬০০০০
- 0xA0060000
অননুমোদিত APDU:
- ০x০০৮০০০০০০
- ০x৮০০৬০০০০
- 0xA008000000
- 0x9406000000
0xA000000476416E64726F696443545341
অনুমোদিত এপিডিইউ:
- ০x৯৪০০৬০০০০
- 0x9408000000
- 0x940C000001AA00
- 0x940A000001AA
অননুমোদিত APDU:
- ০x০০০৬০০০
- ০x৮০০৬০০০০
- 0xA0060000
- ০x০০৮০০০০০০
- 0x000A000001AA
- 0x800A000001AA
- 0xA00A000001AA
- 0x8008000000
- 0xA008000000
- 0x000C000001AA00
- 0x800C000001AA00
- 0xA00C000001AA00
0xA000000476416E64726F696443545343
0xA000000476416E64726F696443545345
0xA000000476416E64726F696443545346
অননুমোদিত এইডস
- 0xA000000476416E64726F696443545342
- 0xA000000476416E64726F696443545344
- 0xA000000476416E64726F696443545347
- 0xA000000476416E64726F696443545348
- 0xA000000476416E64726F696443545349
- 0xA000000476416E64726F69644354534A
- 0xA000000476416E64726F69644354534B
- 0xA000000476416E64726F69644354534C
- 0xA000000476416E64726F69644354534D
- 0xA000000476416E64726F69644354534E
- 0xA000000476416E64726F69644354534F
CtsSecureElementAccessControlTestCases3
- এপিকে-এর হ্যাশ: 0x5528ca826da49d0d7329f8117481ccb27b8833aa
অনুমোদিত এইডসমূহ:
0xA000000476416E64726F696443545340
অনুমোদিত এপিডিইউ:
- ০x০০০৬০০০০
- ০x৮০০৬০০০০
- 0xA0060000
- ০x৯৪০০৬০০০০
- 0x000A000001AA
- 0x800A000001AA
- 0xA00A000001AA
- 0x940A000001AA
- ০x০০৮০০০০০০
- 0x8008000000
- 0xA008000000
- 0x9408000000
- 0x000C000001AA00
- 0x800C000001AA00
- A00C000001AA00
- 940C000001AA00
0xA000000476416E64726F696443545341
অনুমোদিত এপিডিইউ:
- ০x৯৪০০৬০০০০
- 0x9408000000
- 0x940C000001AA00
- 0x940A00000aAA
অননুমোদিত APDU:
- ০x০০০৬০০০০
- ০x৮০০৬০০০০
- 0xA0060000
- ০x০০৮০০০০০০
- 0x000A000001AA
- 0x800A000001AA
- 0xA00A000001AA
- 0x8008000000
- 0xA008000000
- 0x000C000001AA00
- 0x800C000001AA00
- 0xA00C000001AA00
0xA000000476416E64726F696443545345
0xA000000476416E64726F696443545346
অননুমোদিত এইডস
- 0xA000000476416E64726F696443545342
- 0xA000000476416E64726F696443545343
- 0xA000000476416E64726F696443545344
- 0xA000000476416E64726F696443545347
- 0xA000000476416E64726F696443545348
- 0xA000000476416E64726F696443545349
- 0xA000000476416E64726F69644354534A
- 0xA000000476416E64726F69644354534B
- 0xA000000476416E64726F69644354534C
- 0xA000000476416E64726F69644354534D
- 0xA000000476416E64726F69644354534E
- 0xA000000476416E64726F69644354534F
পরিশিষ্ট
ইউএমটিএস ইন্টিগ্রেটেড সার্কিট কার্ড (ইউআইসিসি)-এর জন্য নমুনা অ্যাপলেট এবং ইনস্টলেশনের ধাপসমূহ
১. প্যাকেজের বিবরণ
ফাইলের নাম: google-cardlet.cap
প্যাকেজ এআইডি: 6F 6D 61 70 69 63 61 72 64 6C 65 74
সংস্করণ: ১.৬৩
হ্যাশ: 5F72E0A073BA9E61A7358F2FE3F031A99F3F81E9
অ্যাপলেট:
6F 6D 61 70 69 4A 53 52 31 37 37 = সিলেক্টরেসপন্স মডিউল
6F 6D 61 70 69 43 61 63 68 69 6E 67 = XXLResponse মডিউল
আমদানি:
javacard.framework v1.3 - A0000000620101
java.lang v1.0 - A0000000620001
uicc.hci.framework v1.0 - A0000000090005FFFFFFFF8916010000
uicc.hci.services.cardemulation v1.0 - A0000000090005FFFFFFFF8916020100
uicc.hci.services.connectivity v1.0 - A0000000090005FFFFFFFF8916020200
কার্ডে উল্লিখিত আকার: ৩৯৫৯৭
২. ইনস্টলেশনের ধাপসমূহ
যথাযথ পদ্ধতি অনুসরণ করে সিম কার্ডে google-cardlet.cap ফাইলটি লোড করুন (আপনার SE প্রস্তুতকারকদের সাথে যোগাযোগ করে নিশ্চিত হয়ে নিন)।
প্রতিটি অ্যাপলেটের জন্য ইনস্টলেশন কমান্ড চালান।
OMAPI পরীক্ষা
অ্যাপলেট ইনস্টল করার কমান্ড
80E60C00300C6F6D617069636172646C65740B module_AID 10 AID 01000EEF0AA008810101A5038201C0C9000000
মডিউল_এআইডি : 6F 6D 61 70 69 4A 53 52 31 37 37
এআইডি: A000000476416E64726F696443545331
80E60C00310C6F6D617069636172646C65740B module_AID 10 AID 010002C9000
মডিউল_এআইডি : 6F 6D 61 70 69 43 61 63 68 69 6E 67
AID: A000000476416E64726F696443545332
অ্যাক্সেস কন্ট্রোল পরীক্ষা (PKCS#15 কাঠামো ব্যবহার করে টেমপ্লেট)
80E60C003C0C6F6D617069636172646C65740B module_AID 10 AID 01000EEF0AA008810101A5038201C0C9000000
মডিউল_এআইডি : 6F 6D 61 70 69 4A 53 52 31 37 37
এইডস:
- 0xA000000476416E64726F696443545340
- 0xA000000476416E64726F696443545341
- 0xA000000476416E64726F696443545342
- 0xA000000476416E64726F696443545344
- 0xA000000476416E64726F696443545345
- 0xA000000476416E64726F696443545347
- 0xA000000476416E64726F696443545348
- 0xA000000476416E64726F696443545349
- 0xA000000476416E64726F69644354534A
- 0xA000000476416E64726F69644354534B
- 0xA000000476416E64726F69644354534C
- 0xA000000476416E64726F69644354534D
- 0xA000000476416E64726F69644354534E
- 0xA000000476416E64726F69644354534F
CTS টেস্টগুলোর সাথে সামঞ্জস্যপূর্ণ PKCS#15 কাঠামো সেট আপ করার জন্য ধাপে ধাপে কমান্ড জানতে, “Commands for PKCS#15” দেখুন।