ব্লক স্টোর

অনেক ব্যবহারকারী এখনও নতুন অ্যান্ড্রয়েড-চালিত ডিভাইস সেট আপ করার সময় তাদের নিজস্ব শংসাপত্র পরিচালনা করেন। এই ম্যানুয়াল প্রক্রিয়াটি চ্যালেঞ্জিং হয়ে উঠতে পারে এবং প্রায়শই ব্যবহারকারীর অভিজ্ঞতা খারাপ হতে পারে। গুগল প্লে পরিষেবা দ্বারা চালিত একটি লাইব্রেরি, ব্লক স্টোর এপিআই, ব্যবহারকারীর পাসওয়ার্ড সংরক্ষণের সাথে সম্পর্কিত জটিলতা বা সুরক্ষা ঝুঁকি ছাড়াই অ্যাপগুলিকে ব্যবহারকারীর শংসাপত্র সংরক্ষণ করার একটি উপায় প্রদান করে এই সমস্যা সমাধানের চেষ্টা করে।

ব্লক স্টোর এপিআই আপনার অ্যাপকে এমন ডেটা সংরক্ষণ করার অনুমতি দেয় যা পরবর্তীতে নতুন ডিভাইসে ব্যবহারকারীদের পুনরায় প্রমাণীকরণের জন্য পুনরুদ্ধার করা যেতে পারে। এটি ব্যবহারকারীদের জন্য আরও নিরবচ্ছিন্ন অভিজ্ঞতা প্রদান করতে সাহায্য করে, কারণ নতুন ডিভাইসে প্রথমবারের মতো আপনার অ্যাপ চালু করার সময় তাদের সাইন-ইন স্ক্রিন দেখতে হবে না।

ব্লক স্টোর ব্যবহারের সুবিধাগুলির মধ্যে রয়েছে:

  • ডেভেলপারদের জন্য এনক্রিপ্টেড ক্রেডেনশিয়াল স্টোরেজ সলিউশন। সম্ভব হলে ক্রেডেনশিয়ালগুলি এন্ড-টু-এন্ড এনক্রিপ্ট করা হয়।
  • ব্যবহারকারীর নাম এবং পাসওয়ার্ডের পরিবর্তে টোকেন সংরক্ষণ করুন।
  • সাইন-ইন প্রবাহ থেকে ঘর্ষণ দূর করুন।
  • জটিল পাসওয়ার্ড পরিচালনার বোঝা থেকে ব্যবহারকারীদের বাঁচান।
  • গুগল ব্যবহারকারীর পরিচয় যাচাই করে।

শুরু করার আগে

আপনার অ্যাপ প্রস্তুত করতে, নিম্নলিখিত বিভাগগুলির ধাপগুলি সম্পূর্ণ করুন।

আপনার অ্যাপ কনফিগার করুন

আপনার প্রোজেক্ট-লেভেল build.gradle ফাইলে, আপনার buildscript এবং allprojects উভয় বিভাগেই Google এর Maven সংগ্রহস্থল অন্তর্ভুক্ত করুন:

buildscript {
  repositories {
    google()
    mavenCentral()
  }
}

allprojects {
  repositories {
    google()
    mavenCentral()
  }
}

আপনার মডিউলের Gradle বিল্ড ফাইলে Block Store API-এর জন্য Google Play পরিষেবা নির্ভরতা যোগ করুন, যা সাধারণত app/build.gradle হয়:

dependencies {
  implementation 'com.google.android.gms:play-services-auth-blockstore:16.4.0'
}

কিভাবে এটা কাজ করে

ব্লক স্টোর ডেভেলপারদের ১৬ বাইট পর্যন্ত অ্যারে সংরক্ষণ এবং পুনরুদ্ধার করতে দেয়। এটি আপনাকে বর্তমান ব্যবহারকারীর সেশন সম্পর্কিত গুরুত্বপূর্ণ তথ্য সংরক্ষণ করতে দেয় এবং আপনার পছন্দ মতো এই তথ্য সংরক্ষণ করার নমনীয়তা প্রদান করে। এই ডেটা এন্ড-টু-এন্ড এনক্রিপ্ট করা যেতে পারে এবং ব্লক স্টোরকে সমর্থন করে এমন অবকাঠামো ব্যাকআপ এবং পুনরুদ্ধার অবকাঠামোর উপরে তৈরি করা হয়।

এই নির্দেশিকাটি ব্লক স্টোরে ব্যবহারকারীর টোকেন সংরক্ষণের ব্যবহারের ক্ষেত্রে আলোচনা করবে। ব্লক স্টোর ব্যবহার করে একটি অ্যাপ কীভাবে কাজ করবে তা নিম্নলিখিত পদক্ষেপগুলিতে বর্ণিত হয়েছে:

  1. আপনার অ্যাপের প্রমাণীকরণ প্রবাহের সময়, অথবা তার পরে যেকোনো সময়, আপনি ব্যবহারকারীর প্রমাণীকরণ টোকেনটি ব্লক স্টোরে সংরক্ষণ করতে পারেন যাতে পরবর্তীতে তা পুনরুদ্ধার করা যায়।
  2. টোকেনটি স্থানীয়ভাবে সংরক্ষণ করা হবে এবং ক্লাউডেও ব্যাকআপ করা যাবে, সম্ভব হলে এন্ড-টু-এন্ড এনক্রিপ্ট করা হবে।
  3. ব্যবহারকারী যখন একটি নতুন ডিভাইসে পুনরুদ্ধার প্রবাহ শুরু করেন তখন ডেটা স্থানান্তরিত হয়।
  4. যদি ব্যবহারকারী পুনরুদ্ধার প্রবাহের সময় আপনার অ্যাপটি পুনরুদ্ধার করে, তাহলে আপনার অ্যাপটি নতুন ডিভাইসে ব্লক স্টোর থেকে সংরক্ষিত টোকেনটি পুনরুদ্ধার করতে পারবে।

টোকেন সংরক্ষণ করা হচ্ছে

যখন কোনও ব্যবহারকারী আপনার অ্যাপে সাইন ইন করেন, তখন আপনি সেই ব্যবহারকারীর জন্য তৈরি করা প্রমাণীকরণ টোকেনটি ব্লক স্টোরে সংরক্ষণ করতে পারেন। আপনি এই টোকেনটি একটি অনন্য কী জোড়া মান ব্যবহার করে সংরক্ষণ করতে পারেন যার প্রতি এন্ট্রিতে সর্বোচ্চ 4kb থাকে। টোকেনটি সংরক্ষণ করতে, ব্যবহারকারীর শংসাপত্রগুলি সোর্স ডিভাইসে সংরক্ষণ করতে StoreBytesData.Builder এর একটি ইনস্ট্যান্সে setBytes() এবং setKey() কল করুন। ব্লক স্টোরের মাধ্যমে টোকেনটি সংরক্ষণ করার পরে, টোকেনটি এনক্রিপ্ট করা হয় এবং ডিভাইসে স্থানীয়ভাবে সংরক্ষণ করা হয়।

নিম্নলিখিত নমুনাটি স্থানীয় ডিভাইসে প্রমাণীকরণ টোকেন কীভাবে সংরক্ষণ করবেন তা দেখায়:

জাভা

  BlockstoreClient client = Blockstore.getClient(this);
  byte[] bytes1 = new byte[] { 1, 2, 3, 4 };  // Store one data block.
  String key1 = "com.example.app.key1";
  StoreBytesData storeRequest1 = StoreBytesData.Builder()
          .setBytes(bytes1)
          // Call this method to set the key value pair the data should be associated with.
          .setKeys(Arrays.asList(key1))
          .build();
  client.storeBytes(storeRequest1)
    .addOnSuccessListener(result -> Log.d(TAG, "stored " + result + " bytes"))
    .addOnFailureListener(e -> Log.e(TAG, "Failed to store bytes", e));

কোটলিন

  val client = Blockstore.getClient(this)

  val bytes1 = byteArrayOf(1, 2, 3, 4) // Store one data block.
  val key1 = "com.example.app.key1"
  val storeRequest1 = StoreBytesData.Builder()
    .setBytes(bytes1) // Call this method to set the key value with which the data should be associated with.
    .setKeys(Arrays.asList(key1))
    .build()
  client.storeBytes(storeRequest1)
    .addOnSuccessListener { result: Int ->
      Log.d(TAG,
            "Stored $result bytes")
    }
    .addOnFailureListener { e ->
      Log.e(TAG, "Failed to store bytes", e)
    }

ডিফল্ট টোকেন ব্যবহার করুন

কোনও কী ছাড়াই StoreBytes ব্যবহার করে সংরক্ষিত ডেটা ডিফল্ট কী BlockstoreClient.DEFAULT_BYTES_DATA_KEY ব্যবহার করে।

জাভা

  BlockstoreClient client = Blockstore.getClient(this);
  // The default key BlockstoreClient.DEFAULT_BYTES_DATA_KEY.
  byte[] bytes = new byte[] { 9, 10 };
  StoreBytesData storeRequest = StoreBytesData.Builder()
          .setBytes(bytes)
          .build();
  client.storeBytes(storeRequest)
    .addOnSuccessListener(result -> Log.d(TAG, "stored " + result + " bytes"))
    .addOnFailureListener(e -> Log.e(TAG, "Failed to store bytes", e));

কোটলিন

  val client = Blockstore.getClient(this);
  // the default key BlockstoreClient.DEFAULT_BYTES_DATA_KEY.
  val bytes = byteArrayOf(1, 2, 3, 4)
  val storeRequest = StoreBytesData.Builder()
    .setBytes(bytes)
    .build();
  client.storeBytes(storeRequest)
    .addOnSuccessListener { result: Int ->
      Log.d(TAG,
            "stored $result bytes")
    }
    .addOnFailureListener { e ->
      Log.e(TAG, "Failed to store bytes", e)
    }

টোকেনটি পুনরুদ্ধার করা হচ্ছে

পরবর্তীতে, যখন কোনও ব্যবহারকারী একটি নতুন ডিভাইসে পুনরুদ্ধার প্রবাহের মধ্য দিয়ে যায়, তখন Google Play পরিষেবাগুলি প্রথমে ব্যবহারকারীকে যাচাই করে, তারপর আপনার ব্লক স্টোর ডেটা পুনরুদ্ধার করে। ব্যবহারকারী ইতিমধ্যেই পুনরুদ্ধার প্রবাহের অংশ হিসাবে আপনার অ্যাপ ডেটা পুনরুদ্ধার করতে সম্মত হয়েছেন, তাই কোনও অতিরিক্ত সম্মতির প্রয়োজন নেই। ব্যবহারকারী যখন আপনার অ্যাপটি খোলেন, তখন আপনি retrieveBytes() কল করে ব্লক স্টোর থেকে আপনার টোকেনের অনুরোধ করতে পারেন। পুনরুদ্ধার করা টোকেনটি ব্যবহারকারীকে নতুন ডিভাইসে সাইন ইন রাখতে ব্যবহার করা যেতে পারে।

নিম্নলিখিত নমুনাটি নির্দিষ্ট কীগুলির উপর ভিত্তি করে একাধিক টোকেন কীভাবে পুনরুদ্ধার করতে হয় তা দেখায়।

জাভা

BlockstoreClient client = Blockstore.getClient(this);

// Retrieve data associated with certain keys.
String key1 = "com.example.app.key1";
String key2 = "com.example.app.key2";
String key3 = BlockstoreClient.DEFAULT_BYTES_DATA_KEY; // Used to retrieve data stored without a key

List requestedKeys = Arrays.asList(key1, key2, key3); // Add keys to array
RetrieveBytesRequest retrieveRequest = new RetrieveBytesRequest.Builder()
    .setKeys(requestedKeys)
    .build();

client.retrieveBytes(retrieveRequest)
    .addOnSuccessListener(
        result -> {
          Map<String, BlockstoreData> blockstoreDataMap = result.getBlockstoreDataMap();
          for (Map.Entry<String, BlockstoreData> entry : blockstoreDataMap.entrySet()) {
            Log.d(TAG, String.format(
                "Retrieved bytes %s associated with key %s.",
                new String(entry.getValue().getBytes()), entry.getKey()));
          }
        })
    .addOnFailureListener(e -> Log.e(TAG, "Failed to store bytes", e));

কোটলিন

val client = Blockstore.getClient(this)

// Retrieve data associated with certain keys.
val key1 = "com.example.app.key1"
val key2 = "com.example.app.key2"
val key3 = BlockstoreClient.DEFAULT_BYTES_DATA_KEY // Used to retrieve data stored without a key

val requestedKeys = Arrays.asList(key1, key2, key3) // Add keys to array

val retrieveRequest = RetrieveBytesRequest.Builder()
  .setKeys(requestedKeys)
  .build()

client.retrieveBytes(retrieveRequest)
  .addOnSuccessListener { result: RetrieveBytesResponse ->
    val blockstoreDataMap =
      result.blockstoreDataMap
    for ((key, value) in blockstoreDataMap) {
      Log.d(ContentValues.TAG, String.format(
        "Retrieved bytes %s associated with key %s.",
        String(value.bytes), key))
    }
  }
  .addOnFailureListener { e: Exception? ->
    Log.e(ContentValues.TAG,
          "Failed to store bytes",
          e)
  }

সমস্ত টোকেন পুনরুদ্ধার করা হচ্ছে।

ব্লকস্টোরে সংরক্ষিত সমস্ত টোকেন কীভাবে পুনরুদ্ধার করবেন তার একটি উদাহরণ নীচে দেওয়া হল।

জাভা

BlockstoreClient client = Blockstore.getClient(this)

// Retrieve all data.
RetrieveBytesRequest retrieveRequest = new RetrieveBytesRequest.Builder()
    .setRetrieveAll(true)
    .build();

client.retrieveBytes(retrieveRequest)
    .addOnSuccessListener(
        result -> {
          Map<String, BlockstoreData> blockstoreDataMap = result.getBlockstoreDataMap();
          for (Map.Entry<String, BlockstoreData> entry : blockstoreDataMap.entrySet()) {
            Log.d(TAG, String.format(
                "Retrieved bytes %s associated with key %s.",
                new String(entry.getValue().getBytes()), entry.getKey()));
          }
        })
    .addOnFailureListener(e -> Log.e(TAG, "Failed to store bytes", e));

কোটলিন

val client = Blockstore.getClient(this)

val retrieveRequest = RetrieveBytesRequest.Builder()
  .setRetrieveAll(true)
  .build()

client.retrieveBytes(retrieveRequest)
  .addOnSuccessListener { result: RetrieveBytesResponse ->
    val blockstoreDataMap =
      result.blockstoreDataMap
    for ((key, value) in blockstoreDataMap) {
      Log.d(ContentValues.TAG, String.format(
        "Retrieved bytes %s associated with key %s.",
        String(value.bytes), key))
    }
  }
  .addOnFailureListener { e: Exception? ->
    Log.e(ContentValues.TAG,
          "Failed to store bytes",
          e)
  }

ডিফল্ট কী কীভাবে পুনরুদ্ধার করবেন তার একটি উদাহরণ নিচে দেওয়া হল।

জাভা

BlockStoreClient client = Blockstore.getClient(this);
RetrieveBytesRequest retrieveRequest = new RetrieveBytesRequest.Builder()
    .setKeys(Arrays.asList(BlockstoreClient.DEFAULT_BYTES_DATA_KEY))
    .build();
client.retrieveBytes(retrieveRequest);

কোটলিন

val client = Blockstore.getClient(this)

val retrieveRequest = RetrieveBytesRequest.Builder()
  .setKeys(Arrays.asList(BlockstoreClient.DEFAULT_BYTES_DATA_KEY))
  .build()
client.retrieveBytes(retrieveRequest)

টোকেন মুছে ফেলা হচ্ছে

নিম্নলিখিত কারণে ব্লকস্টোর থেকে টোকেন মুছে ফেলার প্রয়োজন হতে পারে:

  • ব্যবহারকারী সাইন আউট ব্যবহারকারী প্রবাহের মধ্য দিয়ে যান।
  • টোকেনটি বাতিল করা হয়েছে অথবা অবৈধ।

টোকেন পুনরুদ্ধারের মতো, আপনি মুছে ফেলার জন্য প্রয়োজনীয় কীগুলির একটি অ্যারে সেট করে কোন টোকেনগুলি মুছে ফেলা প্রয়োজন তা নির্দিষ্ট করতে পারেন।

নিম্নলিখিত উদাহরণটি দেখায় যে কীভাবে নির্দিষ্ট কীগুলি মুছে ফেলা যায়:

জাভা

BlockstoreClient client = Blockstore.getClient(this);

// Delete data associated with certain keys.
String key1 = "com.example.app.key1";
String key2 = "com.example.app.key2";
String key3 = BlockstoreClient.DEFAULT_BYTES_DATA_KEY; // Used to delete data stored without key

List requestedKeys = Arrays.asList(key1, key2, key3) // Add keys to array
DeleteBytesRequest deleteRequest = new DeleteBytesRequest.Builder()
      .setKeys(requestedKeys)
      .build();
client.deleteBytes(deleteRequest)

কোটলিন

val client = Blockstore.getClient(this)

// Retrieve data associated with certain keys.
val key1 = "com.example.app.key1"
val key2 = "com.example.app.key2"
val key3 = BlockstoreClient.DEFAULT_BYTES_DATA_KEY // Used to retrieve data stored without a key

val requestedKeys = Arrays.asList(key1, key2, key3) // Add keys to array

val retrieveRequest = DeleteBytesRequest.Builder()
      .setKeys(requestedKeys)
      .build()

client.deleteBytes(retrieveRequest)

সমস্ত টোকেন মুছুন

নিম্নলিখিত উদাহরণটি দেখায় যে কীভাবে ব্লকস্টোরে বর্তমানে সংরক্ষিত সমস্ত টোকেন মুছে ফেলা যায়:

জাভা

// Delete all data.
DeleteBytesRequest deleteAllRequest = new DeleteBytesRequest.Builder()
      .setDeleteAll(true)
      .build();
client.deleteBytes(deleteAllRequest)
.addOnSuccessListener(result -> Log.d(TAG, "Any data found and deleted? " + result));

কোটলিন

  val deleteAllRequest = DeleteBytesRequest.Builder()
  .setDeleteAll(true)
  .build()
retrieve bytes, the key BlockstoreClient.DEFAULT_BYTES_DATA_KEY can be used
in the RetrieveBytesRequest instance in order to get your saved data

The following example shows how to retrieve the default key.

Java

End-to-end encryption

In order for end-to-end encryption to be made available, the device must be running Android 9 or higher, and the user must have set a screen lock (PIN, pattern, or password) for their device. You can verify if encryption will be available on the device by calling isEndToEndEncryptionAvailable().

The following sample shows how to verify if encryption will be available during cloud backup:

client.isEndToEndEncryptionAvailable()
        .addOnSuccessListener { result ->
          Log.d(TAG, "Will Block Store cloud backup be end-to-end encrypted? $result")
        }

ক্লাউড ব্যাকআপ সক্ষম করুন

ক্লাউড ব্যাকআপ সক্ষম করতে, আপনার StoreBytesData অবজেক্টে setShouldBackupToCloud() পদ্ধতিটি যোগ করুন। setShouldBackupToCloud() সত্য হিসাবে সেট করা থাকলে ব্লক স্টোর পর্যায়ক্রমে সংরক্ষিত বাইটগুলিকে ক্লাউডে ব্যাকআপ করবে।

নিম্নলিখিত নমুনাটি দেখায় যে ক্লাউড ব্যাকআপ কেবল তখনই কীভাবে সক্ষম করা যায় যখন ক্লাউড ব্যাকআপ এন্ড-টু-এন্ড এনক্রিপ্ট করা থাকে :

val client = Blockstore.getClient(this)
val storeBytesDataBuilder = StoreBytesData.Builder()
        .setBytes(/* BYTE_ARRAY */)

client.isEndToEndEncryptionAvailable()
        .addOnSuccessListener { isE2EEAvailable ->
          if (isE2EEAvailable) {
            storeBytesDataBuilder.setShouldBackupToCloud(true)
            Log.d(TAG, "E2EE is available, enable backing up bytes to the cloud.")

            client.storeBytes(storeBytesDataBuilder.build())
                .addOnSuccessListener { result ->
                  Log.d(TAG, "stored: ${result.getBytesStored()}")
                }.addOnFailureListener { e ->
                  Log.e(TAG, Failed to store bytes, e)
                }
          } else {
            Log.d(TAG, "E2EE is not available, only store bytes for D2D restore.")
          }
        }

কিভাবে পরীক্ষা করবেন

পুনরুদ্ধার প্রবাহ পরীক্ষা করার জন্য বিকাশের সময় নিম্নলিখিত পদ্ধতিগুলি ব্যবহার করুন।

একই ডিভাইস আনইনস্টল/পুনরায় ইনস্টল করুন

যদি ব্যবহারকারী ব্যাকআপ পরিষেবা সক্ষম করে (এটি সেটিংস > গুগল > ব্যাকআপ এ চেক করা যেতে পারে), তাহলে অ্যাপ আনইনস্টল/পুনঃইনস্টল জুড়ে ব্লক স্টোর ডেটা বজায় থাকে।

পরীক্ষা করার জন্য আপনি এই পদক্ষেপগুলি অনুসরণ করতে পারেন:

  1. আপনার পরীক্ষামূলক অ্যাপে ব্লক স্টোর API ইন্টিগ্রেট করুন।
  2. আপনার ডেটা সংরক্ষণের জন্য ব্লক স্টোর API ব্যবহার করতে পরীক্ষা অ্যাপটি ব্যবহার করুন।
  3. আপনার পরীক্ষামূলক অ্যাপটি আনইনস্টল করুন এবং তারপর একই ডিভাইসে আপনার অ্যাপটি পুনরায় ইনস্টল করুন।
  4. আপনার ডেটা পুনরুদ্ধার করতে ব্লক স্টোর API চালু করতে পরীক্ষা অ্যাপটি ব্যবহার করুন।
  5. যাচাই করুন যে পুনরুদ্ধার করা বাইটগুলি আনইনস্টল করার আগে সংরক্ষিত বাইটগুলির মতোই।

ডিভাইস থেকে ডিভাইসে

বেশিরভাগ ক্ষেত্রে, এর জন্য টার্গেট ডিভাইসের ফ্যাক্টরি রিসেট প্রয়োজন হবে। এরপর আপনি অ্যান্ড্রয়েড ওয়্যারলেস রিস্টোর ফ্লো অথবা গুগল কেবল রিস্টোর (সমর্থিত ডিভাইসের জন্য) প্রবেশ করতে পারেন।

ক্লাউড পুনরুদ্ধার

  1. আপনার টেস্ট অ্যাপে ব্লক স্টোর API ইন্টিগ্রেট করুন। টেস্ট অ্যাপটি প্লে স্টোরে জমা দিতে হবে।
  2. সোর্স ডিভাইসে, shouldBackUpToCloud true এ সেট করে, আপনার ডেটা সংরক্ষণের জন্য Block Store API চালু করতে test অ্যাপটি ব্যবহার করুন।
  3. O এবং তার উপরের ডিভাইসগুলির জন্য, আপনি ম্যানুয়ালি একটি ব্লক স্টোর ক্লাউড ব্যাকআপ ট্রিগার করতে পারেন: সেটিংস > গুগল > ব্যাকআপ এ যান, "এখনই ব্যাকআপ করুন" বোতামে ক্লিক করুন।
    1. ব্লক স্টোর ক্লাউড ব্যাকআপ সফল হয়েছে কিনা তা যাচাই করতে, আপনি যা করতে পারেন:
      1. ব্যাকআপ শেষ হওয়ার পর, "CloudSyncBpTkSvc" ট্যাগ সহ লগ লাইনগুলি অনুসন্ধান করুন।
      2. তুমি এই ধরণের লাইন দেখতে পাবে: “......, CloudSyncBpTkSvc: সিঙ্ক ফলাফল: সাফল্য, ..., আপলোড করা আকার: XXX বাইট ...”
    2. ব্লক স্টোর ক্লাউড ব্যাকআপের পরে, ৫ মিনিটের "কুল ডাউন" সময়কাল থাকে। সেই ৫ মিনিটের মধ্যে, "এখনই ব্যাকআপ করুন" বোতামে ক্লিক করলে আর কোনও ব্লক স্টোর ক্লাউড ব্যাকআপ ট্রিগার হবে না।
  4. টার্গেট ডিভাইসটি ফ্যাক্টরি রিসেট করুন এবং ক্লাউড রিস্টোর ফ্লো ব্যবহার করুন। রিস্টোর ফ্লো চলাকালীন আপনার পরীক্ষামূলক অ্যাপটি রিস্টোর করতে নির্বাচন করুন। ক্লাউড রিস্টোর ফ্লো সম্পর্কে আরও তথ্যের জন্য, সাপোর্টেড ক্লাউড রিস্টোর ফ্লো দেখুন।
  5. টার্গেট ডিভাইসে, আপনার ডেটা পুনরুদ্ধার করতে ব্লক স্টোর API চালু করতে টেস্ট অ্যাপ ব্যবহার করুন।
  6. যাচাই করুন যে উদ্ধার করা বাইটগুলি সোর্স ডিভাইসে সংরক্ষিত বাইটগুলির মতোই।

ডিভাইসের প্রয়োজনীয়তা

এন্ড টু এন্ড এনক্রিপশন

  • অ্যান্ড্রয়েড ৯ (এপিআই ২৯) এবং তার পরবর্তী ভার্সনে চলমান ডিভাইসগুলিতে এন্ড টু এন্ড এনক্রিপশন সমর্থিত।
  • ব্যবহারকারীর ডেটা সঠিকভাবে এনক্রিপ্ট করার জন্য এবং এন্ড-টু-এন্ড এনক্রিপশন সক্ষম করার জন্য ডিভাইসটিতে একটি পিন, প্যাটার্ন বা পাসওয়ার্ড সহ একটি স্ক্রিন লক সেট থাকতে হবে।

ডিভাইস থেকে ডিভাইস পুনরুদ্ধার প্রবাহ

ডিভাইস থেকে ডিভাইস পুনরুদ্ধারের জন্য আপনার একটি সোর্স ডিভাইস এবং একটি টার্গেট ডিভাইস থাকা প্রয়োজন। এই দুটি ডিভাইসই ডেটা স্থানান্তর করবে।

ব্যাকআপ নেওয়ার জন্য সোর্স ডিভাইসগুলিতে Android 6 (API 23) এবং তার উপরে চলমান থাকতে হবে।

অ্যান্ড্রয়েড ৯ (এপিআই ২৯) এবং তার উপরে চলমান ডিভাইসগুলিকে পুনরুদ্ধার করার ক্ষমতা প্রদানের জন্য লক্ষ্য করুন

ডিভাইস থেকে ডিভাইস পুনরুদ্ধার প্রবাহ সম্পর্কে আরও তথ্য এখানে পাওয়া যাবে।

ক্লাউড ব্যাকআপ এবং পুনরুদ্ধার প্রবাহ

ক্লাউড ব্যাকআপ এবং পুনরুদ্ধারের জন্য একটি সোর্স ডিভাইস এবং একটি টার্গেট ডিভাইসের প্রয়োজন হবে।

ব্যাকআপ নেওয়ার জন্য সোর্স ডিভাইসগুলিতে Android 6 (API 23) এবং তার উপরে চলমান থাকতে হবে।

টার্গেট ডিভাইসগুলি তাদের বিক্রেতাদের উপর ভিত্তি করে সমর্থিত। Pixel ডিভাইসগুলি Android 9 (API 29) থেকে এই বৈশিষ্ট্যটি ব্যবহার করতে পারে এবং অন্যান্য সমস্ত ডিভাইস অবশ্যই Android 12 (API 31) বা তার উপরে চলমান থাকতে হবে।