এই কুইকস্টার্টে, আপনি আপনার অ্যাকাউন্টের জন্য একটি OAuth টোকেন পাবেন এবং এক্সপোর্ট করা ডেটা ফিল্টার করতে টাইমস্ট্যাম্প ব্যবহার করে ডেটা পোর্টেবিলিটি API এন্ডপয়েন্টে অনুরোধ পাঠান।
সময়-ভিত্তিক অ্যাক্সেস সহ ডেটা পোর্টেবিলিটি API কীভাবে ব্যবহার করতে হয় এবং সমর্থিত সংস্থানগুলির জন্য সময় ফিল্টারগুলি প্রয়োগ করতে হয় তা এই কুইকস্টার্ট কভার করে। ব্যবহারকারীর ডেটাতে সময়-ভিত্তিক অ্যাক্সেস সম্পর্কে আরও বিশদ বিবরণের জন্য, সময়-ভিত্তিক অ্যাক্সেস ব্যবহার করুন দেখুন।
আপনি কি শিখুন
এই কুইকস্টার্টে আপনি শিখবেন কিভাবে:
- আপনার শেষ রপ্তানির পর থেকে শুধুমাত্র নতুন ডেটা রপ্তানি করতে
InitiatePortabilityArchive
এন্ডপয়েন্টে পুনরাবৃত্ত প্রমাণীকৃত অনুরোধ পাঠান। -
InitiatePortabilityArchive
এন্ডপয়েন্টে একটি প্রমাণীকৃত অনুরোধ পাঠান শুধুমাত্র গত 6 মাসের ডেটা এক্সপোর্ট করতে। -
InitiatePortabilityArchive
এন্ডপয়েন্টে একটি প্রমাণিত অনুরোধ পাঠান শুধুমাত্র একটি নির্দিষ্ট সময়কাল থেকে ডেটা এক্সপোর্ট করতে।
পূর্বশর্ত
এই কুইকস্টার্ট চালানোর জন্য, আপনাকে করতে হবে:
- যাচাই করুন যে ডেটা পোর্টেবিলিটি API আপনার অবস্থানের ব্যবহারকারীদের জন্য উপলব্ধ। সমর্থিত দেশ এবং অঞ্চলগুলির একটি তালিকার জন্য, "একটি তৃতীয় পক্ষের সাথে আপনার ডেটার একটি অনুলিপি ভাগ করুন" পৃষ্ঠায় সাধারণ প্রশ্নগুলি দেখুন৷
- ডেটা পোর্টেবিলিটি API-এর জন্য সেটআপ পদক্ষেপগুলি সম্পূর্ণ করুন৷
- JavaScript ওয়েব অ্যাপের জন্য OAuth কনফিগার করার ধাপগুলি অনুসরণ করুন। উৎপাদনে, আপনি সাধারণত ওয়েব সার্ভার অ্যাপ্লিকেশনের জন্য OAuth প্রবাহের মতো একটি ভিন্ন প্রবাহ ব্যবহার করবেন। সরলতার জন্য, এই কুইকস্টার্ট জাভাস্ক্রিপ্ট ওয়েব অ্যাপ ফ্লো ব্যবহার করে।
- আপনি যখন আপনার অনুমোদনের শংসাপত্র তৈরি করেন, তখন আপনার OAuth 2.0 ক্লায়েন্ট আইডি এবং আপনার অনুমোদিত রিডাইরেক্ট URI (উদাহরণস্বরূপ, https://google.com) একটি নোট করুন। কুইকস্টার্টে পরে আপনার সেগুলি দরকার৷
- আপনি যখন ডেটা পোর্টেবিলিটি API-এর জন্য স্কোপগুলি কনফিগার করেন , তখন মনে রাখবেন যে এই কুইকস্টার্টটি
myactivity.search
রিসোর্স গ্রুপ ব্যবহার করে: https://www.googleapis.com/auth/dataportability.myactivity.search। - আপনি যখন অ্যাক্সেসের অনুমতি দিতে চান এমন সময় নির্বাচন করার সময়, সময়-ভিত্তিক অ্যাক্সেসের সাথে সময় ফিল্টারিং পরীক্ষা করার জন্য আপনার 30 দিন নির্বাচন করা উচিত। (টাইম ফিল্টারগুলি এককালীন অ্যাক্সেসের সাথেও কাজ করে)।
- একটি OAuth টোকেন পান।
- আপনার প্রতিষ্ঠানের মালিকানাধীন বা নিয়ন্ত্রিত অ্যাকাউন্টে অ্যাক্সেস পান। এই অ্যাকাউন্টের সার্চ অ্যাক্টিভিটি ডেটা এই কুইকস্টার্টে এক্সপোর্ট করা হয়।
একটি OAuth টোকেন পান
এই কুইকস্টার্টের জন্য, আপনি একটি URL ব্যবহার করে একটি OAuth টোকেন পাওয়ার জন্য একটি অনুমোদনের অনুরোধ পাঠান। এই প্রক্রিয়াটি JavaScript ওয়েব অ্যাপের জন্য প্রবাহ ব্যবহার করে। এই প্রবাহটি রিফ্রেশ টোকেন ফেরত দেয় না।
একটি প্রোডাকশন অ্যাপের জন্য, আপনি সাধারণত একটি রিফ্রেশ টোকেন পেতে একটি OAuth ফ্লো ব্যবহার করবেন যা চাহিদা অনুযায়ী অ্যাক্সেস টোকেন তৈরি করতে ব্যবহার করা যেতে পারে। এর একটি উদাহরণ হবে সার্ভার-সাইড ওয়েব অ্যাপের প্রবাহ।
একটি OAuth টোকেন পেতে:
নিচের মত একটি URL রচনা করুন।
https://accounts.google.com/o/oauth2/v2/auth? client_id=client_id& redirect_uri=redirect_uri& response_type=token& scope=https://www.googleapis.com/auth/dataportability.myactivity.search& state=developer-specified-value
URL-এ:
-
client_id
হল আপনার OAuth ক্লায়েন্ট আইডি। -
redirect_uri
হল আপনার অনুমোদিত রিডাইরেক্ট URI; উদাহরণস্বরূপ, https://google.com।
লক্ষ্য করুন যে এই কুইকস্টার্টের জন্য ইউআরএলে যে স্কোপ ব্যবহার করা হয়েছে সেটি হল সার্চ অ্যাক্টিভিটি স্কোপ। আপনি সময় ফিল্টার সমর্থন করে এমন কোনো স্কোপ ব্যবহার করতে পারেন।
-
আপনার ব্রাউজারের ঠিকানা বারে URLটি আটকান এবং OAuth প্রবাহের ধাপগুলি অনুসরণ করুন৷ এই প্রবাহের জন্য আপনাকে আপনার প্রতিষ্ঠানের মালিকানাধীন বা নিয়ন্ত্রিত অ্যাকাউন্টে সাইন ইন করতে হবে যা আপনি এই দ্রুত শুরুর জন্য ব্যবহার করছেন।
এটি সেই অ্যাকাউন্ট যা OAuth স্কোপের সাথে সম্মতি দিচ্ছে। সম্মতি স্ক্রিনটি এইরকম হওয়া উচিত (আপনার স্ক্রিনের পাঠ্য এই চিত্রের পাঠ্য থেকে আলাদা হতে পারে):
অ্যাক্সেস মঞ্জুর করার সুযোগ এবং অ্যাকাউন্টের ডেটাতে অ্যাক্সেস ভাগ করার সময় দৈর্ঘ্য (একবার, 30 দিন বা 180 দিন) চয়ন করুন। এই দ্রুত শুরুর জন্য, 30 দিন বেছে নিন। (টাইম ফিল্টারগুলি এককালীন অ্যাক্সেসের সাথেও কাজ করে।)
সম্মতি দেওয়ার পরে এবং অ্যাক্সেসের সময়কাল নির্ধারণ করার পরে, আপনাকে রিডাইরেক্ট URI—https://google.com-এ ফরোয়ার্ড করা উচিত। ঠিকানা বারে তৈরি করা URLটিতে OAuth অ্যাক্সেস টোকেন অন্তর্ভুক্ত রয়েছে।
উদাহরণ স্বরূপ, যদি ব্যবহারকারীর অ্যাকাউন্ট
dataportability.myactivity.search
স্কোপে OAuth-কে অ্যাক্সেস দেয়, তাহলে জেনারেট করা ইউআরএল দেখতে এইরকম হবে:https://google.com/#state=developer-specified-value&access_token=your_OAuth_token&token_type=Bearer&expires_in=3599&scope=https://www.googleapis.com/auth/dataportability.myactivity.search
URL-এ, your_OAuth_token হল একটি স্ট্রিং যা টোকেনকে উপস্থাপন করে।
OAuth টোকেন যাচাই করতে, আপনার ব্রাউজারে এই URL পেস্ট করুন:
https://www.googleapis.com/oauth2/v3/tokeninfo?access_token=your_OAuth_token
প্রতিক্রিয়া এই মত হওয়া উচিত:
{ "azp": <your_azp_value>, "aud": <your_aud_value>, "scope": "https://www.googleapis.com/auth/dataportability.myactivity.search", "exp": "1694210968", "expires_in": "3334", "access_type": "online" }
অনুরোধ করার জন্য আপনার
azp
বাaud
ফিল্ডের প্রয়োজন নেই।azp
ক্ষেত্রটি অনুমোদিত উপস্থাপকেরclient_id
প্রতিনিধিত্ব করে, এবংaud
ক্ষেত্রটি সেই শ্রোতাদের সনাক্ত করে যার জন্য এই টোকেনটি তৈরি করা হয়েছে, যা আপনার আবেদনের জন্য ক্লায়েন্ট আইডিগুলির একটির সমান হবে৷আপনার OAuth টোকেন এবং আপনার API কী সংগ্রহ করুন। ডেটা পোর্টেবিলিটি API-তে কল করার জন্য আপনার এগুলোর প্রয়োজন।
শেষ পয়েন্টে অনুরোধ পাঠান
এই কুইকস্টার্টে আপনি রপ্তানি করা ডেটা ফিল্টার করতে টাইমস্ট্যাম্প সহ ডেটা পোর্টেবিলিটি API এন্ডপয়েন্টে কল করতে কার্ল কমান্ড ব্যবহার করেন৷ এই কমান্ডগুলির জন্য আপনার আগে সংগ্রহ করা OAuth টোকেন এবং API কী প্রয়োজন৷
সর্বশেষ রপ্তানি থেকে ডেটা
আপনার শেষ রপ্তানির পর থেকে নতুন ডেটা রপ্তানি করতে আপনি সময়-ভিত্তিক অ্যাক্সেস সহ টাইম ফিল্টার ব্যবহার করতে পারেন। উদাহরণস্বরূপ, সুযোগ বিবেচনা করুন https://www.googleapis.com/auth/dataportability.myactivity.search
।
প্রথমে, আপনি
InitiatePortabilityArchive
এন্ডপয়েন্টে একটি প্রমাণীকৃত অনুরোধ পাঠান। এই অনুরোধটি সম্পূর্ণ ডেটা কর্পাসের জন্য একটি সংরক্ষণাগার কাজ শুরু করে।নিম্নলিখিত কার্ল কমান্ড চালান:
curl -H 'Authorization: Bearer your_OAuth_token' -X POST \ -H "Content-Type: application/json; charset=utf-8" \ --data '{"resources":["myactivity.search"]}' \ https://dataportability.googleapis.com/v1/portabilityArchive:initiate
আদেশে:
-
your_OAuth_token
হল আপনার OAuth টোকেন।
InitiatePortabilityArchive
অনুরোধ একটিarchiveJobId
এবংaccessType
প্রদান করে। কাজের আইডি ডেটা সংরক্ষণাগারের অবস্থা পুনরুদ্ধার করতে ব্যবহার করা হয় এবং অ্যাক্সেসের ধরন নির্ধারণ করে যে আপনাকে ডেটাতে এক-বার বা সময়-ভিত্তিক অ্যাক্সেস দেওয়া হয়েছে কিনা। সময়-ভিত্তিক অ্যাক্সেসের জন্য, আপনি দেখতে পাবেন:{ "archiveJobId": "<your_job_id_1>" "accessType": "ACCESS_TYPE_TIME_BASED" }
আপনি একটি বৈধ OAuth টোকেন প্রদান করতে ব্যর্থ হলে, এই ত্রুটি বার্তাটি ফেরত দেওয়া হয়:
Request had invalid authentication credentials. Expected OAuth 2.0 access token, login cookie or other valid authentication credential. See https://developers.google.com/identity/sign-in/web/devconsole-project.
-
এর পরে, আপনি আর্কাইভ কাজের স্থিতি পুনরুদ্ধার করতে
GetPortabilityArchiveState
এন্ডপয়েন্টে একটি প্রমাণীকৃত অনুরোধ পাঠান।নিম্নলিখিত কার্ল কমান্ড চালান:
curl -H 'Authorization: Bearer your_OAuth_token' -X GET \ -H "Content-Type: application/json; charset=utf-8" \ https://dataportability.googleapis.com/v1/archiveJobs/your_job_id_1/portabilityArchiveState
আদেশে:
-
your_OAuth_token
হল আপনার OAuth টোকেন। -
your_job_id_1
হল চাকরির আইডি যাInitiatePortabilityArchive
অনুরোধ দ্বারা ফেরত দেওয়া হয়।
প্রতিক্রিয়া কাজের অবস্থার উপর ভিত্তি করে। কাজ সম্পূর্ণ না হলে, প্রতিক্রিয়া বর্তমান অবস্থা প্রদান করে। কাজ সম্পূর্ণ না হওয়া পর্যন্ত আপনাকে পর্যায়ক্রমে এই এন্ডপয়েন্টে অনুরোধ পাঠাতে হবে।
{ "state": "IN_PROGRESS" }
কাজটি সম্পূর্ণ হলে, প্রতিক্রিয়াতে রাজ্য এবং এক বা একাধিক স্বাক্ষরিত URL থাকে যা ডেটা সংরক্ষণাগার ডাউনলোড করতে ব্যবহৃত হয়। এছাড়াও একটি
export_time
ক্ষেত্র রয়েছে যা টাইমস্ট্যাম্পের প্রতিনিধিত্ব করে যখনInitiatePortabilityArchive
এ প্রথম কল করা হয়েছিল।{ "state": "COMPLETE", "urls": [ "<signed_url>" ] "export_time": "<timestamp_of_first_initiate_request>" }
ডেটা সংরক্ষণাগারটি ডাউনলোড করতে আপনার ব্রাউজারে স্বাক্ষরিত URLটি আটকান৷ আপনার সংরক্ষণাগারের বিষয়বস্তু পরীক্ষা করা উচিত যাতে এটি প্রত্যাশিত অনুসন্ধান কার্যকলাপ ডেটা ধারণ করে।
আপনি যদি প্রতিক্রিয়াতে একটি
FAILED
অবস্থা পান, আপনিRetryPortabilityArchive
পদ্ধতি ব্যবহার করে রপ্তানির পুনরায় চেষ্টা করতে পারেন।-
কমপক্ষে 24 ঘন্টা অপেক্ষা করুন এবং তারপর ধাপ 1-এর মতো একই কমান্ড ব্যবহার করে
InitiatePortabilityArchive
জন্য আরেকটি অনুরোধ করুন, তবে এবারstart_time
হিসাবেexport_time
ব্যবহার করুন।curl -H 'Authorization: Bearer your_OAuth_token' -X POST \ -H "Content-Type: application/json; charset=utf-8" \ --data '{"resources":["myactivity.search"], "start_time": timestamp_of_first_initiate_request}' \ https://dataportability.googleapis.com/v1/portabilityArchive:initiate
সময়-ভিত্তিক অ্যাক্সেসের জন্য, এটি ফিরে আসবে:
{ "archiveJobId": "<your_job_id_2>" "accessType": "ACCESS_TYPE_TIME_BASED" }
আর্কাইভ কাজের স্থিতি পুনরুদ্ধার করতে
GetPortabilityArchiveState
এন্ডপয়েন্টে একটি প্রমাণীকৃত অনুরোধ পাঠাতে ধাপ 2 পুনরাবৃত্তি করুন (<your_job_id_2>
ব্যবহার করে)।কাজ সম্পূর্ণ হলে, প্রতিক্রিয়া হবে:
{ "state": "COMPLETE", "urls": [ "signed_urls" ], "start_time": timestamp_of_first_initiate_request, "export_time": timestamp_of_second_initiate_request }
যাচাই করুন যে দ্বিতীয় রপ্তানির ডেটাতে শুধুমাত্র প্রথম রপ্তানির পরে উত্পন্ন নতুন ডেটা রয়েছে৷
গত 6 মাসের ডেটা
আপনি সম্পূর্ণ কর্পাসের পরিবর্তে শুধুমাত্র সাম্প্রতিক ডেটা রপ্তানি করতে টাইম ফিল্টার ব্যবহার করতে পারেন।
ধরুন আজকের তারিখ হল
2024-10-01
এবং আপনি শেষ 6 মাসের ডেটা রপ্তানি করতে চান৷ প্রথমে, আপনি "2024-04-01T00:00:00Z" এরstart_time
সহInitiatePortabilityArchive
এন্ডপয়েন্টে একটি প্রমাণীকৃত অনুরোধ পাঠান।নিম্নলিখিত কার্ল কমান্ড চালান:
curl -H 'Authorization: Bearer your_OAuth_token' -X POST \ -H "Content-Type: application/json; charset=utf-8" \ --data '{"resources":["myactivity.search"], "start_time": "2024-04-01T00:00:00Z"}' \ https://dataportability.googleapis.com/v1/portabilityArchive:initiate
সময়-ভিত্তিক অ্যাক্সেসের জন্য, এটি ফিরে আসবে:
{ "archiveJobId": "job_id_1" "accessType": "ACCESS_TYPE_TIME_BASED" }
আর্কাইভ কাজের স্থিতি পুনরুদ্ধার করতে
GetPortabilityArchiveState
এন্ডপয়েন্টে একটি অনুরোধ করুন।নিম্নলিখিত কার্ল কমান্ড চালান:
curl -H 'Authorization: Bearer your_OAuth_token' -X GET \ -H "Content-Type: application/json; charset=utf-8" \ https://dataportability.googleapis.com/v1/archiveJobs/job_id_1/portabilityArchiveState
কাজ সম্পূর্ণ হলে, প্রতিক্রিয়া হবে:
{ "state": "COMPLETE", "urls": [ "signed_urls" ], "start_time": "2024-04-01T00:00:00Z", "export_time": "2024-10-01T00:00:00Z" }
মনে রাখবেন যে
start_time
হলstart_time
ধাপ 1 এ নির্দিষ্ট করা হয়েছে এবংexport_time
হল টাইমস্ট্যাম্প যখনInitiatePortabilityArchive
এ কল করা হয়েছিল 1 ধাপে।যাচাই করুন যে রপ্তানিতে শুধুমাত্র গত ছয় মাসের ডেটা রয়েছে।
একটি নির্দিষ্ট সময়কাল থেকে ডেটা
আপনি তারিখের একটি নির্দিষ্ট পরিসর থেকে ডেটা রপ্তানি করতে টাইম ফিল্টার ব্যবহার করতে পারেন, যেমন শুধুমাত্র 2023 থেকে ডেটা।
প্রথমে, আপনি "2023-01-01T00:00:00Z" এর
start_time
এবং "2023-12-31T23:59:59Z" এর একটিend_time
সহInitiatePortabilityArchive
এন্ডপয়েন্টে একটি প্রমাণীকৃত অনুরোধ পাঠান।নিম্নলিখিত কার্ল কমান্ড চালান:
curl -H 'Authorization: Bearer your_OAuth_token' -X POST \ -H "Content-Type: application/json; charset=utf-8" \ --data '{"resources":["myactivity.search"], "start_time": "2023-01-01T00:00:00Z", "end_time": "2023-12-31T23:59:59Z"}' \ https://dataportability.googleapis.com/v1/portabilityArchive:initiate
সময়-ভিত্তিক অ্যাক্সেসের জন্য, এটি ফিরে আসবে:
{ "archiveJobId": "job_id_1" "accessType": "ACCESS_TYPE_TIME_BASED" }
আর্কাইভ কাজের স্থিতি পুনরুদ্ধার করতে
GetPortabilityArchiveState
এন্ডপয়েন্টে একটি অনুরোধ করুন।নিম্নলিখিত কার্ল কমান্ড চালান:
curl -H 'Authorization: Bearer your_OAuth_token' -X GET \ -H "Content-Type: application/json; charset=utf-8" \ https://dataportability.googleapis.com/v1/archiveJobs/job_id_1/portabilityArchiveState
কাজ সম্পূর্ণ হলে, প্রতিক্রিয়া হবে:
{ "state": "COMPLETE", "urls": [ "signed_urls" ], "start_time": "2023-01-01T00:00:00Z", "export_time": "2023-12-31T23:59:59Z" }
মনে রাখবেন যে
start_time
হলstart_time
ধাপ 1 এ উল্লেখ করা হয়েছে এবংexport_time
ধাপ 1 এ দেওয়াend_time
সমান।যাচাই করুন যে এক্সপোর্টে শুধুমাত্র 2023 সালের ডেটা রয়েছে।
সমর্থিত সুযোগ
নিম্নলিখিত স্কোপ টাইম ফিল্টার সমর্থন করে:
-
https://www.googleapis.com/auth/dataportability.myactivity.youtube
-
https://www.googleapis.com/auth/dataportability.myactivity.maps
-
https://www.googleapis.com/auth/dataportability.myactivity.search
-
https://www.googleapis.com/auth/dataportability.myactivity.myadcenter
-
https://www.googleapis.com/auth/dataportability.myactivity.shopping
-
https://www.googleapis.com/auth/dataportability.myactivity.play
-
https://www.googleapis.com/auth/dataportability.chrome.history
সতর্কতা: সমর্থিত এবং অসমর্থিত স্কোপের মিশ্রণের সময়-ফিল্টার করা অনুরোধের ফলে একটি INVALID_ARGUMENT
ত্রুটি দেখা দেয় যা বলে The requested resources do not support time filters
৷