হেলথ কানেক্টের সাথে একীভূত বেশিরভাগ অ্যাপের নিজস্ব ডেটাস্টোর থাকে যা সত্যের উৎস হিসেবে কাজ করে। হেলথ কানেক্ট আপনার অ্যাপকে সিঙ্কে রাখার উপায় প্রদান করে।
আপনার অ্যাপের আর্কিটেকচারের উপর নির্ভর করে, সিঙ্ক প্রক্রিয়াটিতে নিম্নলিখিত কিছু বা সমস্ত ক্রিয়া জড়িত থাকতে পারে:
- আপনার অ্যাপের ডেটাস্টোর থেকে Health Connect-এ নতুন বা আপডেট করা ডেটা ফিড করুন।
- হেলথ কানেক্ট থেকে ডেটা পরিবর্তনগুলি আপনার অ্যাপের ডেটাস্টোরে টেনে আনুন।
- আপনার অ্যাপের ডেটাস্টোর থেকে ডেটা মুছে ফেলা হলে Health Connect থেকে ডেটা মুছে ফেলুন।
প্রতিটি ক্ষেত্রেই, নিশ্চিত করুন যে সিঙ্কিং প্রক্রিয়াটি হেলথ কানেক্ট এবং আপনার অ্যাপের ডেটাস্টোর উভয়কেই সারিবদ্ধ রাখে।
হেলথ কানেক্টে ডেটা ফিড করুন
সিঙ্কিং প্রক্রিয়ার প্রথম অংশ হল আপনার অ্যাপের ডেটাস্টোর থেকে হেলথ কানেক্ট ডেটাস্টোরে ডেটা ফিড করা।
আপনার ডেটা প্রস্তুত করুন
সাধারণত, আপনার অ্যাপের ডেটাস্টোরের রেকর্ডগুলিতে নিম্নলিখিত বিবরণ থাকে:
- একটি অনন্য কী, যেমন একটি
UUID
। - একটি সংস্করণ বা টাইমস্ট্যাম্প।
Health Connect-এ ডেটা সিঙ্ক করার সময়, শুধুমাত্র শেষ সিঙ্কের পর থেকে যে ডেটা সন্নিবেশ করা হয়েছে, আপডেট করা হয়েছে বা মুছে ফেলা হয়েছে তা সনাক্ত করুন এবং ফিড করুন।
Health Connect-এ ডেটা লিখুন
হেলথ কানেক্টে ডেটা ফিড করতে, নিম্নলিখিত পদক্ষেপগুলি সম্পাদন করুন:
- আপনার অ্যাপের ডেটাস্টোর থেকে নতুন, আপডেট করা বা মুছে ফেলা এন্ট্রিগুলির একটি তালিকা পান।
- প্রতিটি এন্ট্রির জন্য, সেই ডেটা টাইপের জন্য উপযুক্ত একটি
Record
অবজেক্ট তৈরি করুন। উদাহরণস্বরূপ, ওজন সম্পর্কিত ডেটার জন্য একটিWeightRecord
অবজেক্ট তৈরি করুন। প্রতিটি
Record
এর সাথে একটিMetadata
অবজেক্ট নির্দিষ্ট করুন। এর মধ্যে রয়েছেclientRecordId
, যা আপনার অ্যাপের ডেটাস্টোরের একটি আইডি যা আপনি রেকর্ডটিকে অনন্যভাবে সনাক্ত করতে ব্যবহার করতে পারেন। আপনি এর জন্য আপনার বিদ্যমান অনন্য কী ব্যবহার করতে পারেন। যদি আপনার ডেটা ভার্সন করা হয়, তাহলে একটিclientRecordVersion
ও প্রদান করুন যা আপনার ডেটাতে ব্যবহৃত ভার্সনের সাথে সামঞ্জস্যপূর্ণ। যদি এটি ভার্সন না করা হয়, তাহলে আপনি বিকল্প হিসেবে বর্তমান টাইমস্ট্যাম্পেরLong
মান ব্যবহার করতে পারেন।val recordVersion = 0L // Specify as needed // The clientRecordId is an ID that you choose for your record. This // is often the same ID you use in your app's datastore. val clientRecordId = "<your-record-id>" val record = WeightRecord( metadata = Metadata.activelyRecorded( clientRecordId = clientRecordId, clientRecordVersion = recordVersion, device = Device(type = Device.TYPE_SCALE) ), weight = Mass.kilograms(62.0), time = Instant.now(), zoneOffset = ZoneOffset.UTC, ) healthConnectClient.insertRecords(listOf()(record))
insertRecords
ব্যবহার করে Health Connect-এ ডেটা আপসার্ট করুন । ডেটা আপসার্ট করার অর্থ হল Health Connect-এ বিদ্যমান যেকোনো ডেটা ওভাররাইট করা হবে যতক্ষণ পর্যন্তclientRecordId
মান Health Connect ডেটাস্টোরে বিদ্যমান থাকে এবংclientRecordVersion
বিদ্যমান মানের চেয়ে বেশি থাকে। অন্যথায়, আপসার্ট করা ডেটা নতুন ডেটা হিসাবে লেখা হবে।healthConnectClient.insertRecords(arrayListOf(record))
ডেটা ফিডিংয়ের ব্যবহারিক বিবেচ্য বিষয়গুলি সম্পর্কে জানতে, Write data এর সেরা অনুশীলনগুলি দেখুন।
স্টোর হেলথ কানেক্ট আইডি
যদি আপনার অ্যাপটি হেলথ কানেক্ট থেকে ডেটাও পড়ে, তাহলে রেকর্ড আপসার্ট করার পরে হেলথ কানেক্ট id
সংরক্ষণ করুন। হেলথ কানেক্ট থেকে ডেটা পরিবর্তনগুলি সংগ্রহ করার সময় মুছে ফেলার প্রক্রিয়া করার জন্য আপনার এই id
প্রয়োজন।
insertRecords
ফাংশনটি একটি InsertRecordsResponse
প্রদান করে যাতে id
মানের তালিকা থাকে। Record ID গুলি পেতে এবং সেগুলি সংরক্ষণ করতে প্রতিক্রিয়াটি ব্যবহার করুন।
val response = healthConnectClient.insertRecords(arrayListOf(record))
for (recordId in response.recordIdsList) {
// Store recordId to your app's datastore
}
Health Connect থেকে ডেটা সংগ্রহ করুন
সিঙ্কিং প্রক্রিয়ার দ্বিতীয় অংশ হল Health Connect থেকে আপনার অ্যাপের ডেটাস্টোরে যেকোনো ডেটা পরিবর্তনের জন্য তথ্য সংগ্রহ করা। ডেটা পরিবর্তনের মধ্যে আপডেট এবং মুছে ফেলা অন্তর্ভুক্ত থাকতে পারে।
একটি পরিবর্তন টোকেন পান
Health Connect থেকে পরিবর্তনের তালিকা পেতে, আপনার অ্যাপটিকে Changes টোকেনগুলির ট্র্যাক রাখতে হবে। Changes অনুরোধ করার সময় আপনি ডেটা পরিবর্তনের তালিকা এবং পরের বার ব্যবহার করার জন্য একটি নতুন Changes টোকেন উভয়ই ফেরত দেওয়ার জন্য এগুলি ব্যবহার করতে পারেন।
একটি পরিবর্তন টোকেন পেতে, getChangesToken
কল করুন এবং প্রয়োজনীয় ডেটা টাইপ সরবরাহ করুন।
val changesToken = healthConnectClient.getChangesToken(
ChangesTokenRequest(recordTypes = setOf(WeightRecord::class))
)
ডেটা পরিবর্তনের জন্য পরীক্ষা করুন
এখন যেহেতু আপনি একটি Changes টোকেন পেয়েছেন, তাই এটি ব্যবহার করে সমস্ত Changes পাবেন। আমরা আপনাকে সমস্ত Changes এর মধ্য দিয়ে যাওয়ার জন্য একটি লুপ তৈরি করার পরামর্শ দিচ্ছি যেখানে এটি উপলব্ধ ডেটা পরিবর্তন আছে কিনা তা পরীক্ষা করে। নিম্নলিখিত পদক্ষেপগুলি এখানে দেওয়া হল:
- Changes এর তালিকা পেতে টোকেন ব্যবহার করে
getChanges
কল করুন। - প্রতিটি পরিবর্তনের ধরণ
UpsertionChange
নাকিDeletionChange
তা পরীক্ষা করে দেখুন এবং প্রয়োজনীয় ক্রিয়াকলাপগুলি সম্পাদন করুন।-
UpsertionChange
এর জন্য, শুধুমাত্র সেই পরিবর্তনগুলি নিন যা কলিং অ্যাপ থেকে আসেনি যাতে নিশ্চিত করা যায় যে আপনি ডেটা পুনরায় আমদানি করছেন না।
-
- পরবর্তী পরিবর্তন টোকেনটিকে আপনার নতুন টোকেন হিসেবে বরাদ্দ করুন।
- কোনও পরিবর্তন না হওয়া পর্যন্ত ধাপ ১-৩ পুনরাবৃত্তি করুন।
- পরবর্তী টোকেনটি সংরক্ষণ করুন এবং ভবিষ্যতে আমদানির জন্য এটি সংরক্ষণ করুন।
suspend fun processChanges(token: String): String {
var nextChangesToken = token
do {
val response = healthConnectClient.getChanges(nextChangesToken)
response.changes.forEach { change ->
when (change) {
is UpsertionChange ->
if (change.record.metadata.dataOrigin.packageName != context.packageName) {
processUpsertionChange(change)
}
is DeletionChange -> processDeletionChange(change)
}
}
nextChangesToken = response.nextChangesToken
} while (response.hasMore)
// Return and store the changes token for use next time.
return nextChangesToken
}
ডেটা সংগ্রহের ব্যবহারিক বিবেচ্য বিষয়গুলি সম্পর্কে জানতে, সিঙ্ক ডেটার জন্য সেরা অনুশীলনগুলি দেখুন।
প্রক্রিয়া তথ্য পরিবর্তন
আপনার অ্যাপের ডেটাস্টোরে পরিবর্তনগুলি প্রতিফলিত করুন। UpsertionChange
এর জন্য, রেকর্ডটি আপসার্ট করতে এর metadata
থেকে id
এবং lastModifiedTime
ব্যবহার করুন। DeletionChange
এর জন্য, রেকর্ডটি মুছে ফেলার জন্য প্রদত্ত id
ব্যবহার করুন। এর জন্য আপনাকে Store Health Connect IDs এ উল্লিখিত রেকর্ড id
সংরক্ষণ করতে হবে।
Health Connect থেকে ডেটা মুছুন
যখন কোনও ব্যবহারকারী আপনার অ্যাপ থেকে তাদের নিজস্ব ডেটা মুছে ফেলেন, তখন নিশ্চিত করুন যে ডেটাটি Health Connect থেকেও মুছে ফেলা হয়েছে । এটি করার জন্য deleteRecords
ব্যবহার করুন। এটি একটি রেকর্ড টাইপ এবং id
এবং clientRecordId
মানের তালিকা নেয়, যা মুছে ফেলার জন্য একাধিক ডেটা ব্যাচ করা সুবিধাজনক করে তোলে। একটি বিকল্প deleteRecords
যা একটি timeRangeFilter
নেয়RangeFilterও উপলব্ধ।
ডেটা সিঙ্ক করার জন্য সেরা পদ্ধতি
নিম্নলিখিত বিষয়গুলি সিঙ্কিং প্রক্রিয়াকে প্রভাবিত করে।
টোকেনের মেয়াদ শেষ
যেহেতু একটি অব্যবহৃত পরিবর্তন টোকেনের মেয়াদ 30 দিনের মধ্যে শেষ হয়ে যায়, তাই আপনাকে অবশ্যই একটি সিঙ্ক কৌশল ব্যবহার করতে হবে যা এই ক্ষেত্রে তথ্য হারানো এড়াবে। আপনার কৌশলটিতে নিম্নলিখিত পদ্ধতিগুলি অন্তর্ভুক্ত থাকতে পারে:
- আপনার অ্যাপ ডেটাস্টোরে অনুসন্ধান করুন যেটি সম্প্রতি ব্যবহৃত রেকর্ড, যার একটি Health Connect
id
আছে। - Health Connect থেকে একটি নির্দিষ্ট টাইমস্ট্যাম্প দিয়ে শুরু হওয়া রেকর্ডের অনুরোধ করুন এবং তারপর আপনার অ্যাপের ডেটাস্টোরে সেগুলি সন্নিবেশ বা আপডেট করুন।
- পরবর্তী প্রয়োজনে এটি সংরক্ষণ করার জন্য একটি পরিবর্তন টোকেনের অনুরোধ করুন।
প্রস্তাবিত পরিবর্তন ব্যবস্থাপনা কৌশল
যদি আপনার অ্যাপটি অবৈধ বা মেয়াদোত্তীর্ণ পরিবর্তন টোকেন পেয়ে যায়, তাহলে আপনার লজিকে এর প্রয়োগের উপর নির্ভর করে আমরা নিম্নলিখিত ব্যবস্থাপনা কৌশলগুলি সুপারিশ করি:
- সমস্ত তথ্য পড়ুন এবং নকল করুন । এটি সবচেয়ে আদর্শ কৌশল।
- Health Connect থেকে তারা শেষবার যখন ডেটা পড়েছিল তার টাইমস্ট্যাম্প সংরক্ষণ করুন।
- টোকেনের মেয়াদ শেষ হয়ে গেলে, সাম্প্রতিক টাইমস্ট্যাম্প বা গত 30 দিনের সমস্ত ডেটা পুনরায় পড়ুন। তারপর, শনাক্তকারী ব্যবহার করে পূর্বে পঠিত ডেটার সাথে এটিকে ডিডুয়েট করুন।
- আদর্শভাবে, ক্লায়েন্ট আইডি বাস্তবায়ন করুন কারণ ডেটা আপডেটের জন্য এগুলি প্রয়োজন।
- শুধুমাত্র শেষ পঠিত টাইমস্ট্যাম্প থেকে পঠিত ডেটা । এর ফলে পরিবর্তন টোকেনের মেয়াদ শেষ হওয়ার সময় কিছু ডেটার অসঙ্গতি দেখা দেয়, তবে সময়কাল কম থাকে যার জন্য কয়েক ঘন্টা থেকে কয়েক দিন সময় লাগতে পারে।
- Health Connect থেকে তারা শেষবার যখন ডেটা পড়েছিল তার টাইমস্ট্যাম্প সংরক্ষণ করুন।
- টোকেনের মেয়াদ শেষ হওয়ার পরে, এই টাইমস্ট্যাম্প থেকে পরবর্তী সমস্ত ডেটা পড়ুন।
- গত ৩০ দিনের ডেটা মুছে ফেলুন এবং পড়ুন । এটি প্রথম ইন্টিগ্রেশনে যা ঘটে তার সাথে আরও ঘনিষ্ঠভাবে সারিবদ্ধ হয়।
- গত 30 দিনের জন্য Health Connect থেকে অ্যাপ দ্বারা পঠিত সমস্ত ডেটা মুছে ফেলুন।
- একবার মুছে ফেলা হলে, এই সমস্ত ডেটা আবার পড়ুন।
- গত ৩০ দিনের ডেটা ডিডুপ না করে পড়ুন । এটি সবচেয়ে আদর্শ কৌশল, এবং এর ফলে ব্যবহারকারীদের কাছে ডুপ্লিকেট ডেটা প্রদর্শিত হয়।
- গত 30 দিনের জন্য Health Connect থেকে অ্যাপ দ্বারা পঠিত সমস্ত ডেটা মুছে ফেলুন।
- ডুপ্লিকেট এন্ট্রির অনুমতি দিন।
ডেটা টাইপ পরিবর্তন টোকেন
যদি আপনার অ্যাপটি একাধিক ডেটা টাইপ স্বাধীনভাবে ব্যবহার করে, তাহলে প্রতিটি ডেটা টাইপের জন্য আলাদা আলাদা Changes Tokens ব্যবহার করুন। Changes Sync API-এর সাথে একাধিক ডেটা টাইপের তালিকা ব্যবহার করুন যদি এই ডেটা টাইপগুলি একসাথে ব্যবহার করা হয় অথবা একেবারেই না করা হয়।
ফোরগ্রাউন্ড রিডস
অ্যাপগুলি কেবল তখনই Health Connect থেকে ডেটা পড়তে পারে যখন তারা ফোরগ্রাউন্ডে থাকে। Health Connect থেকে ডেটা সিঙ্ক করার সময়, Health Connect-এ অ্যাক্সেস যেকোনো সময় বাধাগ্রস্ত হতে পারে। উদাহরণস্বরূপ, Health Connect থেকে প্রচুর পরিমাণে ডেটা পড়ার সময় সিঙ্কের মাঝখানে আপনার অ্যাপটিকে বাধাগুলি মোকাবেলা করতে হবে এবং পরের বার অ্যাপটি খোলার সময় চালিয়ে যেতে হবে।
পটভূমি পাঠ
আপনি আপনার অ্যাপ্লিকেশনটিকে ব্যাকগ্রাউন্ডে চালানোর এবং হেলথ কানেক্ট থেকে ডেটা পড়ার অনুরোধ করতে পারেন। আপনি যদি Background Read
অনুমতি চান, তাহলে আপনার ব্যবহারকারী আপনার অ্যাপটিকে ব্যাকগ্রাউন্ডে ডেটা পড়ার অ্যাক্সেস দিতে পারবেন।
আমদানির সময়
যেহেতু আপনার অ্যাপটি নতুন ডেটা সম্পর্কে বিজ্ঞপ্তি পাচ্ছে না, তাই দুটি পয়েন্টে নতুন ডেটার জন্য পরীক্ষা করুন:
- প্রতিবার যখন আপনার অ্যাপটি ফোরগ্রাউন্ডে সক্রিয় হয়। এই ক্ষেত্রে, লাইফসাইকেল ইভেন্ট ব্যবহার করুন।
- আপনার অ্যাপটি যখন সামনের দিকে থাকে, তখন পর্যায়ক্রমে। নতুন ডেটা উপলব্ধ হলে ব্যবহারকারীদের অবহিত করুন, যাতে তারা পরিবর্তনগুলি প্রতিফলিত করতে তাদের স্ক্রিন আপডেট করতে পারে।