spinny:~/writing $ vim passkeys-webauthn-passwordless-authentication.md
1~2পাসওয়ার্ডগুলি সেই জিনিসগুলির মধ্যে একটি যা আমরা স্বাভাবিক করেছি কারণ আমরা তাদের সাথে বছরের পর বছর বেঁচে আছি৷ ব্যবহারকারীরা সেগুলি ভুলে যান, পুনঃব্যবহার করেন, যেখানে তাদের উচিত নয় সেখানে লিখুন৷ দলগুলিকে অবশ্যই রিসেট, নীতি, হ্যাশ, ফাঁস, ফিশিং এবং সমর্থন পরিচালনা করতে হবে।3~4passkey প্রমাণীকরণকে নিখুঁত করে না, তবে তারা একটি বিশাল সমস্যা দূর করে: সার্ভারকে আর ব্যবহারকারীর সাথে শেয়ার করা গোপনীয়তা রাখতে হবে না।5~6## আসলে কি হয়7~8A passkey হল WebAuthn এর উপর ভিত্তি করে একটি শংসাপত্র। যখন ব্যবহারকারী এটি তৈরি করে, ডিভাইসটি একটি কী জোড়া তৈরি করে:9~10- একটি ব্যক্তিগত কী, যা ডিভাইসে বা পাসওয়ার্ড ম্যানেজারে থাকে;11- একটি সর্বজনীন কী, যা সার্ভার সংরক্ষণ করতে পারে।12~13সার্ভারে লগ ইন করার সময় "পাসওয়ার্ড বলুন" জিজ্ঞাসা করবেন না। একটি র্যান্ডম চ্যালেঞ্জ পাঠান. ডিভাইসটি ব্যক্তিগত কী দিয়ে এটি স্বাক্ষর করে। সার্ভার পাবলিক কী দিয়ে স্বাক্ষর যাচাই করে।14~15এটি চমৎকার অংশ: ডাটাবেস চুরি হলে, ক্র্যাক করার জন্য ভিতরে কোন পাসওয়ার্ড নেই। এবং যদি একজন ব্যবহারকারী একটি জাল ডোমেনে শেষ করে, passkey সেই ডোমেনের জন্য বৈধ নয়৷ এটি কেবল সুবিধা নয়, এটি ফিশিংয়ের বিরুদ্ধে কংক্রিট সুরক্ষা।16~17## ব্রাউজার একটি সেতু হিসাবে কাজ করে18~19ব্রাউজারে দুটি প্রধান API হল:20~21- `navigator.credentials.create()` একটি passkey তৈরি করতে;22- লগইন করার সময় এটি ব্যবহার করতে `navigator.credentials.get()`।23~24কিন্তু গুরুত্বপূর্ণ যুক্তিটি সার্ভারে রয়েছে। সার্ভারকে অবশ্যই চ্যালেঞ্জ জেনারেট করতে হবে, অস্থায়ীভাবে সংরক্ষণ করতে হবে, প্রতিক্রিয়া যাচাই করতে হবে, উৎস পরীক্ষা করতে হবে এবং Relying Party ID, তারপর সেশন তৈরি করতে হবে।25~26ক্লায়েন্ট অংশ প্রায় বিরক্তিকর হওয়া উচিত:27~28```typescript29const options = await fetch('/api/passkeys/login/options').then((r) => r.json());30~31const credential = await navigator.credentials.get({32 publicKey: PublicKeyCredential.parseRequestOptionsFromJSON(options),33});34~35await fetch('/api/passkeys/login/verify', {36 method: 'POST',37 headers: { 'Content-Type': 'application/json' },38 body: JSON.stringify(credential?.toJSON()),39});40```41~42আপনি যদি নিজের হাতে WebAuthn এনক্রিপশন বাস্তবায়ন করতে দেখেন, তাহলে থামুন। একটি শক্তিশালী সার্ভার-সাইড লাইব্রেরি ব্যবহার করুন। এখানে ত্রুটিগুলি "চতুর বাগ" নয়, সেগুলি প্রমাণীকরণের গর্ত।43~44## ডাটাবেসে কি সেভ করবেন45~46অর্ধেক পৃথিবী বাঁচানোর দরকার নেই। সাধারণত যথেষ্ট:47~48- শংসাপত্রের আইডি;49- পাবলিক কী;50- সংযুক্ত ব্যবহারকারী;51- কোনো যাচাইকরণ কাউন্টার বা মেটাডেটা;52- পরিবহন, যদি UX এর জন্য উপযোগী হয়;53- ব্যবহারকারীর দ্বারা নির্বাচিত নাম;54- তৈরির তারিখ এবং শেষ ব্যবহার।55~56একটি ন্যূনতম টেবিল এই মত দেখতে পারে:57~58```sql59create table passkey_credentials (60 id uuid primary key default gen_random_uuid(),61 user_id uuid not null references users(id),62 credential_id text not null unique,63 public_key text not null,64 name text,65 created_at timestamptz not null default now(),66 last_used_at timestamptz67);68```69~70তারপর আমি অডিট লগ এবং বিজ্ঞপ্তিগুলি যোগ করব: যদি কেউ আমার অ্যাকাউন্টে একটি নতুন passkey তৈরি করে, আমি এটি সম্পর্কে জানতে চাই৷71~72## ডেমোর চেয়ে UX গুরুত্বপূর্ণ73~74একটি passkey এর ডেমো সর্বদা সুন্দর: আপনি ক্লিক করুন, Face ID, আপনি প্রবেশ করেছেন৷ প্রকৃত পণ্যটি আরও জটিল৷75~76কেউ তাদের ফোন পরিবর্তন. কেউ লক করা কোম্পানির কম্পিউটার ব্যবহার করে। কিছু লোক বুঝতে পারে না কেন ব্রাউজার একটি passkey প্রস্তাব করে। কেউ তার ডিভাইস অ্যাক্সেস হারান.77~78এই কারণেই আমি "আজ থেকে সবার জন্য আর পাসওয়ার্ড নেই" দিয়ে শুরু করব না। আমি এই মত শুরু করব:79~801. অভ্যন্তরীণ ব্যবহারকারীদের জন্য passkey ঐচ্ছিক;812. একটি সফল লগইন করার পরে একটি তৈরি করার পরামর্শ;823. অ্যাকাউন্ট পৃষ্ঠা পুনঃনামকরণ এবং অপসারণ passkey;834. পরিষ্কার ফলব্যাক;845. প্রধান লগইনে ধীরে ধীরে রোলআউট।85~86ইন্টারফেসের পাঠ্যটি সহজ হওয়া উচিত। "আপনার ডিভাইসের লক স্ক্রিন ব্যবহার করুন" "একটি বাসিন্দা FIDO2 শংসাপত্রের সাথে প্রমাণীকরণ" এর চেয়ে ভাল৷87~88## ভুলগুলো এড়িয়ে চলতাম89~90ক্লায়েন্টের উপর চ্যালেঞ্জ তৈরি করবেন না। চ্যালেঞ্জটি সার্ভারে তৈরি করা হয়েছে এবং শুধুমাত্র একবার যাচাই করতে হবে।91~92শুধুমাত্র শংসাপত্র আইডি বিশ্বাস করবেন না. আপনাকে স্বাক্ষর, চ্যালেঞ্জ, উৎপত্তি এবং Relying Party ID যাচাই করতে হবে।93~94ভাল পুনরুদ্ধার প্রবাহের আগে ফলব্যাকগুলি মুছবেন না। পাসওয়ার্ডহীন হয়ে উঠতে হবে না "যদি আপনি আপনার ফোন হারিয়ে ফেলেন তাহলে আপনি চিরতরে আউট হয়ে যাবেন"।95~96passkey কে সম্পূর্ণরূপে ফ্রন্টএন্ড বোতাম হিসাবে বিবেচনা করবেন না। একটি বোতাম লুকানো নিরাপত্তা নয়: আসল যাচাইকরণ সার্ভার-সাইড।97~98## Passkey-প্রথম নাকি passkey-বন্ধুত্বপূর্ণ?99~100একটি নতুন পণ্যের জন্য আপনি passkey-প্রথমে ভাবতে পারেন। একটি বিদ্যমান অ্যাপের জন্য আমি passkey-বন্ধুত্বপূর্ণ পছন্দ করি: একটি প্রস্তাবিত পদ্ধতি হিসাবে passkey যোগ করুন, সাফল্য এবং সমস্যাগুলি পরিমাপ করুন, তারপর শান্তভাবে পাসওয়ার্ডের ওজন হ্রাস করুন৷101~102আদর্শ মাইগ্রেশন অনুভূত হয় না. ব্যবহারকারী আবিষ্কার করেন যে লগ ইন করা সহজ, কোম্পানিটি তার প্রমাণীকরণ প্রোটোকল পরিবর্তন করেছে এমন নয়।103~104## উপসংহার105~106passkey আকর্ষণীয় কারণ তারা একই সময়ে নিরাপত্তা এবং UX উন্নত করে, যা বিরল। এগুলি কোনও জাদুর কাঠি নয়: পুনরুদ্ধার, সামঞ্জস্যতা, সমর্থন এবং রোলআউটগুলি ভালভাবে ডিজাইন করা উচিত।107~108কিন্তু মৌলিক পরিবর্তন শক্তিশালী। ব্যবহারকারীদের উদ্ভাবন এবং গোপনীয়তা রক্ষা করতে বলা বন্ধ করুন। আপনি ডিভাইসটিকে আপনার ডোমেনের সাথে সংযুক্ত একটি ক্রিপ্টোগ্রাফিক প্রমাণ স্বাক্ষর করতে দেন। কম মানুষের মেমরি, কম ফিশিং, কম পাসওয়ার্ড রিসেট। আমি বলব যে তারা গুরুত্ব সহকারে নেওয়ার যোগ্য।109~110## সূত্র111~112- [MDN: Passkeys](https://developer.mozilla.org/en-US/docs/Web/Security/Authentication/Passkeys)113- [MDN: Web Authentication API](https://developer.mozilla.org/en-US/docs/Web/API/Web_Authentication_API)114- [W3C: Web Authentication](https://www.w3.org/TR/webauthn-3/)115- [passkeys.dev](https://passkeys.dev/)116~
NORMAL · passkeys-webauthn-passwordless-authentication.md [readonly]116 lines · :q to close