স্থানীয় পরিপূর্ণতা সমর্থন করার জন্য, আপনাকে এই স্মার্ট হোম ইন্টেন্টগুলি পরিচালনা করার জন্য একটি অ্যাপ তৈরি করতে হবে:
-
IDENTIFY: স্থানীয়ভাবে-নিয়ন্ত্রিত স্মার্ট ডিভাইসের আবিষ্কার সমর্থন করে। ইনটেন্ট হ্যান্ডলার আপনার স্মার্ট ডিভাইসটি আবিষ্কারের সময় যে ডেটা ফেরত দেয় তা বের করে এবং Google-কে একটি প্রতিক্রিয়া হিসাবে পাঠায়। -
EXECUTE: কমান্ড কার্যকর করা সমর্থন করে। -
QUERY: ডিভাইসের স্থিতি জিজ্ঞাসা সমর্থন করে। -
REACHABLE_DEVICES: (ঐচ্ছিক) একটি হাব (বা সেতু) ডিভাইসের পিছনে স্থানীয়ভাবে-নিয়ন্ত্রিত শেষ ডিভাইসগুলির আবিষ্কারকে সমর্থন করে।
এই অ্যাপটি ব্যবহারকারীর Google Home বা Google Nest ডিভাইসে চলে এবং আপনার স্মার্ট ডিভাইসটিকে Assistant-এর সাথে কানেক্ট করে। আপনি টাইপস্ক্রিপ্ট (পছন্দের) বা জাভাস্ক্রিপ্ট ব্যবহার করে অ্যাপ তৈরি করতে পারেন।
TypeScript সুপারিশ করা হয়েছে কারণ আপনি স্ট্যাটিকভাবে নিশ্চিত করতে বাইন্ডিংগুলিকে লিভারেজ করতে পারেন যে আপনার অ্যাপটি যে ধরনের ডেটা প্ল্যাটফর্ম আশা করে তার সাথে মেলে।
API সম্পর্কে আরও বিশদ বিবরণের জন্য, স্থানীয় হোম SDK API রেফারেন্স দেখুন।
নিম্নলিখিত স্নিপেটগুলি দেখায় যে আপনি কীভাবে স্থানীয় পরিপূর্ণতা অ্যাপ শুরু করতে পারেন এবং আপনার হ্যান্ডলারগুলিকে সংযুক্ত করতে পারেন।
import App = smarthome.App; const localHomeApp: App = new App("1.0.0"); localHomeApp .onIdentify(identifyHandler) .onExecute(executeHandler) .listen() .then(() => { console.log("Ready"); });
import App = smarthome.App; const localHomeApp: App = new App("1.0.0"); localHomeApp .onIdentify(identifyHandler) .onReachableDevices(reachableDevicesHandler) .onExecute(executeHandler) .listen() .then(() => { console.log("Ready"); });
আপনার প্রকল্প তৈরি করুন
আপনার স্থানীয় পরিপূর্ণতা অ্যাপ্লিকেশন স্থাপন করার জন্য, আপনাকে আপনার কোড এবং এর সমস্ত নির্ভরতার জন্য একটি জাভাস্ক্রিপ্ট বান্ডেল তৈরি করতে হবে।
আপনার পছন্দের বান্ডলার কনফিগারেশনের সাথে উপযুক্ত প্রজেক্ট স্ট্রাকচার বুটস্ট্র্যাপ করতে স্থানীয় পূর্ণতা অ্যাপ প্রজেক্ট ইনিশিয়ালাইজার ব্যবহার করুন।
প্রকল্প টেমপ্লেট
আপনার বান্ডলার কনফিগারেশন নির্বাচন করতে, নিম্নলিখিত উদাহরণে দেখানো হিসাবে npm init কমান্ডটি চালান:
কোন বান্ডলার কনফিগারেশন ছাড়া টাইপস্ক্রিপ্ট:
npm init @google/local-home-app project-directory/ --bundler none
প্রকল্প কাঠামো:
project-directory/ ├── node_modules/ ├── package.json ├── .gitignore ├── index.ts ├── test.ts ├── tsconfig.json ├── tslint.json └── serve.js
একটি নতুন ডিরেক্টরি দিয়ে project-directory প্রতিস্থাপন করুন যাতে স্থানীয় পূর্ণতা অ্যাপ প্রকল্প থাকবে।
ওয়েবপ্যাক বান্ডলার কনফিগারেশন সহ টাইপস্ক্রিপ্ট:
npm init @google/local-home-app project-directory/ --bundler webpack
প্রকল্প কাঠামো:
project-directory/ ├── node_modules/ ├── package.json ├── .gitignore ├── index.ts ├── test.ts ├── tsconfig.json ├── tslint.json ├── webpack.config.web.js ├── webpack.config.node.js └── serve.js
একটি নতুন ডিরেক্টরি দিয়ে project-directory প্রতিস্থাপন করুন যাতে স্থানীয় পূর্ণতা অ্যাপ প্রকল্প থাকবে।
রোলআপ বান্ডলার কনফিগারেশন সহ টাইপস্ক্রিপ্ট:
npm init @google/local-home-app project-directory/ --bundler rollup
প্রকল্প কাঠামো:
project-directory/ ├── node_modules/ ├── package.json ├── .gitignore ├── index.ts ├── test.ts ├── tsconfig.json ├── tslint.json ├── rollup.config.js └── serve.js
একটি নতুন ডিরেক্টরি দিয়ে project-directory প্রতিস্থাপন করুন যাতে স্থানীয় পূর্ণতা অ্যাপ প্রকল্প থাকবে।
পার্সেল বান্ডলার কনফিগারেশন সহ টাইপস্ক্রিপ্ট:
npm init @google/local-home-app project-directory/ --bundler parcel
প্রকল্প কাঠামো:
project-directory/ ├── node_modules/ ├── package.json ├── .gitignore ├── index.ts ├── test.ts ├── tsconfig.json ├── tslint.json └── serve.js
একটি নতুন ডিরেক্টরি দিয়ে project-directory প্রতিস্থাপন করুন যাতে স্থানীয় পূর্ণতা অ্যাপ প্রকল্প থাকবে।
সাধারণ প্রকল্প-স্তরের কাজগুলি সম্পাদন করুন
উত্পন্ন প্রকল্প নিম্নলিখিত npm স্ক্রিপ্ট সমর্থন করে:
cd project-directory/ npm run build
এই স্ক্রিপ্টটি TypeScript সোর্স কম্পাইল করে, এবং dist/web সাবডিরেক্টরিতে ক্রোম রানটাইম এনভায়রনমেন্ট এবং dist/node সাবডিরেক্টরিতে Node.js রানটাইম এনভায়রনমেন্টের নির্ভরতা সহ আপনার অ্যাপকে বান্ডিল করে।
cd project-directory/ npm run lint npm run compile npm test
এই স্ক্রিপ্টটি আপনার TypeScript কোডের সিনট্যাক্স যাচাই করে, dist/ সাবডিরেক্টরিতে কোনো আউটপুট তৈরি না করেই এটি কম্পাইল করে এবং test.ts থেকে স্বয়ংক্রিয় পরীক্ষা চালায়।
cd project-directory/ npm run start
বিকাশের সময়, এই স্ক্রিপ্ট স্থানীয়ভাবে Chrome এবং Node.js রানটাইম পরিবেশের জন্য আপনার অ্যাপ বান্ডিলগুলি পরিবেশন করে৷
আইডেন্টিফাই হ্যান্ডলার প্রয়োগ করুন
Google Home বা Google Nest ডিভাইস রিবুট হলে এবং যাচাই না করা লোকাল ডিভাইস (হাবের সাথে কানেক্ট করা শেষ ডিভাইস সহ) দেখলে IDENTIFY হ্যান্ডলার ট্রিগার হবে। স্থানীয় হোম প্ল্যাটফর্ম আপনার পূর্বে নির্দিষ্ট করা স্ক্যান কনফিগার তথ্য ব্যবহার করে স্থানীয় ডিভাইসগুলির জন্য স্ক্যান করবে এবং স্ক্যান ফলাফলের সাথে আপনার IDENTIFY হ্যান্ডলারকে কল করবে।
লোকাল হোম প্ল্যাটফর্মের IdentifyRequest একটি LocalIdentifiedDevice ইন্সট্যান্সের স্ক্যান ডেটা থাকে। ডিভাইসটি আবিষ্কার করা স্ক্যান কনফিগারের উপর ভিত্তি করে শুধুমাত্র একটি device উদাহরণ পপুলেট করা হয়েছে।
যদি স্ক্যানের ফলাফলগুলি আপনার ডিভাইসের সাথে মেলে, তাহলে আপনার IDENTIFY হ্যান্ডলারকে একটি IdentifyResponsePayload অবজেক্ট ফেরত দেওয়া উচিত, যাতে স্মার্ট হোম মেটাডেটা (যেমন প্রকার, বৈশিষ্ট্য এবং প্রতিবেদনের অবস্থা) সহ একটি device অবজেক্ট অন্তর্ভুক্ত থাকে।
Google একটি ডিভাইস অ্যাসোসিয়েশন প্রতিষ্ঠা করে যদি IDENTIFY প্রতিক্রিয়া থেকে verificationId SYNC প্রতিক্রিয়া দ্বারা প্রত্যাবর্তিত otherDeviceIds মানের সাথে মেলে।
উদাহরণ
নিম্নলিখিত স্নিপেটগুলি দেখায় কিভাবে আপনি যথাক্রমে স্বতন্ত্র ডিভাইস এবং হাব ইন্টিগ্রেশনের জন্য IDENTIFY হ্যান্ডলার তৈরি করতে পারেন।
const identifyHandler = (request: IntentFlow.IdentifyRequest): IntentFlow.IdentifyResponse => { // Obtain scan data from protocol defined in your scan config const device = request.inputs[0].payload.device; if (device.udpScanData === undefined) { throw Error("Missing discovery response"); } const scanData = device.udpScanData.data; // Decode scan data to obtain metadata about local device const verificationId = "local-device-id"; // Return a response const response: IntentFlow.IdentifyResponse = { intent: Intents.IDENTIFY, requestId: request.requestId, payload: { device: { id: device.id || "", verificationId, // Must match otherDeviceIds in SYNC response }, }, }; return response; };
const identifyHandler = (request: IntentFlow.IdentifyRequest): IntentFlow.IdentifyResponse => { // Obtain scan data from protocol defined in your scan config const device = request.inputs[0].payload.device; if (device.udpScanData === undefined) { throw Error("Missing discovery response"); } const scanData = device.udpScanData.data; // Decode scan data to obtain metadata about local device const proxyDeviceId = "local-hub-id"; // Return a response const response: IntentFlow.IdentifyResponse = { intent: Intents.IDENTIFY, requestId: request.requestId, payload: { device: { id: proxyDeviceId, isProxy: true, // Device can control other local devices isLocalOnly: true, // Device not present in `SYNC` response }, }, }; return response; };
একটি হাবের পিছনে ডিভাইস সনাক্ত করুন
যদি Google একটি হাব ডিভাইস শনাক্ত করে, তাহলে এটি হাবটিকে হাবের সংযুক্ত শেষ ডিভাইসগুলির নল হিসাবে বিবেচনা করবে এবং সেই শেষ ডিভাইসগুলি যাচাই করার চেষ্টা করবে৷
একটি হাব ডিভাইস উপস্থিত রয়েছে তা নিশ্চিত করতে Google সক্ষম করতে, আপনার IDENTIFY হ্যান্ডলারের জন্য এই নির্দেশাবলী অনুসরণ করুন:
- যদি আপনার
SYNCপ্রতিক্রিয়া হাবের সাথে সংযুক্ত স্থানীয় শেষ ডিভাইসগুলির আইডি রিপোর্ট করে, তাহলেIdentifyResponsePayloadএisProxytrueহিসাবে সেট করুন। - যদি আপনার
SYNCপ্রতিক্রিয়া আপনার হাব ডিভাইসের প্রতিবেদন না করে, তাহলেIdentifyResponsePayloadএisLocalOnlytrueহিসাবে সেট করুন। -
device.idক্ষেত্রে হাব ডিভাইসের জন্য স্থানীয় ডিভাইস আইডি রয়েছে।
REACHABLE_DEVICES হ্যান্ডলার প্রয়োগ করুন (শুধুমাত্র হাব ইন্টিগ্রেশন)
কোন শেষ ডিভাইসগুলি স্থানীয়ভাবে নিয়ন্ত্রিত হতে পারে তা নিশ্চিত করতে Google দ্বারা REACHABLE_DEVICES অভিপ্রায় পাঠানো হয়৷ যতক্ষণ না হাবটি অনলাইনে শনাক্ত হয় ততক্ষণ পর্যন্ত Google যখন একটি আবিষ্কার স্ক্যান চালায় (প্রায় প্রতি মিনিটে একবার) এই অভিপ্রায়টি ট্রিগার হয়৷
আপনি REACHABLE_DEVICES হ্যান্ডলারটিকে IDENTIFY হ্যান্ডলারের মতোই প্রয়োগ করেন, আপনার হ্যান্ডলারকে স্থানীয় প্রক্সি (অর্থাৎ হাব) ডিভাইসের মাধ্যমে পৌঁছানো যায় এমন অতিরিক্ত ডিভাইস আইডি সংগ্রহ করতে হবে। device.verificationId ফিল্ডে হাবের সাথে সংযুক্ত একটি শেষ ডিভাইসের স্থানীয় ডিভাইস আইডি রয়েছে।
Local Home প্ল্যাটফর্মের ReachableDevicesRequest এ LocalIdentifiedDevice এর একটি উদাহরণ রয়েছে। এই উদাহরণের মাধ্যমে, আপনি প্রক্সি ডিভাইস আইডির পাশাপাশি স্ক্যান ফলাফল থেকে ডেটা পেতে পারেন।
আপনার REACHABLE_DEVICES হ্যান্ডলারের একটি ReachableDevicesPayload অবজেক্ট ফেরত দেওয়া উচিত যাতে এমন একটি devices অবজেক্ট রয়েছে যাতে একটি verificationId মানগুলির একটি অ্যারে রয়েছে যা হাব নিয়ন্ত্রণ করে এমন শেষ ডিভাইসগুলিকে প্রতিনিধিত্ব করে৷ verificationId মানগুলি অবশ্যই SYNC প্রতিক্রিয়া থেকে otherDeviceIds একটির সাথে মিলবে৷
নিম্নলিখিত স্নিপেটটি দেখায় কিভাবে আপনি আপনার REACHABLE_DEVICES হ্যান্ডলার তৈরি করতে পারেন৷
const reachableDevicesHandler = (request: IntentFlow.ReachableDevicesRequest): IntentFlow.ReachableDevicesResponse => { // Reference to the local proxy device const proxyDeviceId = request.inputs[0].payload.device.id; // Gather additional device ids reachable by local proxy device // ... const reachableDevices = [ // Each verificationId must match one of the otherDeviceIds // in the SYNC response { verificationId: "local-device-id-1" }, { verificationId: "local-device-id-2" }, ]; // Return a response const response: IntentFlow.ReachableDevicesResponse = { intent: Intents.REACHABLE_DEVICES, requestId: request.requestId, payload: { devices: reachableDevices, }, }; return response; };
EXECUTE হ্যান্ডলার প্রয়োগ করুন
অ্যাপে আপনার EXECUTE হ্যান্ডলার ব্যবহারকারীর আদেশগুলি প্রক্রিয়া করে এবং একটি বিদ্যমান প্রোটোকলের মাধ্যমে আপনার স্মার্ট ডিভাইসগুলি অ্যাক্সেস করতে স্থানীয় হোম SDK ব্যবহার করে।
স্থানীয় হোম প্ল্যাটফর্মটি আপনার ক্লাউড পরিপূর্ণতার জন্য EXECUTE উদ্দেশ্যের মতো EXECUTE হ্যান্ডলার ফাংশনে একই ইনপুট পেলোড পাস করে। একইভাবে, আপনার EXECUTE হ্যান্ডলার EXECUTE উদ্দেশ্য প্রক্রিয়াকরণের মতো একই বিন্যাসে আউটপুট ডেটা প্রদান করে। প্রতিক্রিয়া তৈরিকে সহজ করার জন্য, আপনি Execute.Response.Builder ক্লাস ব্যবহার করতে পারেন যা Local Home SDK প্রদান করে।
আপনার অ্যাপের ডিভাইসের IP ঠিকানায় সরাসরি অ্যাক্সেস নেই। পরিবর্তে, এই প্রোটোকলগুলির একটির উপর ভিত্তি করে কমান্ড তৈরি করতে CommandRequest ইন্টারফেস ব্যবহার করুন: UDP, TCP, বা HTTP। তারপর, কমান্ড পাঠাতে deviceManager.send() ফাংশনটিতে কল করুন।
ডিভাইসগুলিতে কমান্ড টার্গেট করার সময়, ডিভাইসের সাথে যোগাযোগ করতে SYNC প্রতিক্রিয়া থেকে ডিভাইস ID (এবং customData ক্ষেত্রের প্যারামিটারগুলি, যদি অন্তর্ভুক্ত থাকে) ব্যবহার করুন।
উদাহরণ
নিম্নলিখিত কোড স্নিপেট দেখায় কিভাবে আপনি আপনার EXECUTE হ্যান্ডলার তৈরি করতে পারেন।
const executeHandler = (request: IntentFlow.ExecuteRequest): Promise<IntentFlow.ExecuteResponse> => { // Extract command(s) and device target(s) from request const command = request.inputs[0].payload.commands[0]; const execution = command.execution[0]; const response = new Execute.Response.Builder() .setRequestId(request.requestId); const result = command.devices.map((device) => { // Target id of the device provided in the SYNC response const deviceId = device.id; // Metadata for the device provided in the SYNC response // Use customData to provide additional required execution parameters const customData: any = device.customData; // Convert execution command into payload for local device let devicePayload: string; // ... // Construct a local device command over TCP const deviceCommand = new DataFlow.TcpRequestData(); deviceCommand.requestId = request.requestId; deviceCommand.deviceId = deviceId; deviceCommand.data = devicePayload; deviceCommand.port = customData.port; deviceCommand.operation = Constants.TcpOperation.WRITE; // Send command to the local device return localHomeApp.getDeviceManager() .send(deviceCommand) .then((result) => { response.setSuccessState(result.deviceId, state); }) .catch((err: IntentFlow.HandlerError) => { err.errorCode = err.errorCode || IntentFlow.ErrorCode.INVALID_REQUEST; response.setErrorState(device.id, err.errorCode); }); }); // Respond once all commands complete return Promise.all(result) .then(() => response.build()); };
QUERY হ্যান্ডলার প্রয়োগ করুন৷
অ্যাপে আপনার QUERY হ্যান্ডলার ব্যবহারকারীর অনুরোধগুলি প্রক্রিয়া করে এবং আপনার স্মার্ট ডিভাইসগুলির অবস্থা রিপোর্ট করতে স্থানীয় হোম SDK ব্যবহার করে৷
স্থানীয় হোম প্ল্যাটফর্ম 'QUERY' হ্যান্ডলার ফাংশনে আপনার ক্লাউড পূরণের জন্য QUERY উদ্দেশ্যের মতো একই অনুরোধ পেলোড পাস করে। একইভাবে, আপনার QUERY হ্যান্ডলার QUERY উদ্দেশ্য প্রক্রিয়াকরণের মতো একই বিন্যাসে ডেটা প্রদান করে৷
একটি হাবের পিছনে ডিভাইসগুলিতে কমান্ড পাঠানো হচ্ছে
একটি হাবের পিছনের শেষ ডিভাইসগুলি নিয়ন্ত্রণ করতে, আপনাকে হাবে পাঠানো প্রোটোকল-নির্দিষ্ট কমান্ড পেলোডে অতিরিক্ত তথ্য সরবরাহ করতে হতে পারে যাতে হাবটি নির্দেশ করে কোন ডিভাইসের জন্য নির্দেশিত তা সনাক্ত করতে। কিছু ক্ষেত্রে, এটি সরাসরি device.id মান থেকে অনুমান করা যেতে পারে, কিন্তু যখন এটি হয় না, তখন আপনাকে customData ক্ষেত্রের অংশ হিসাবে এই অতিরিক্ত ডেটা অন্তর্ভুক্ত করা উচিত।
আপনি যদি TypeScript ব্যবহার করে আপনার অ্যাপ তৈরি করেন, তাহলে আপনার অ্যাপটিকে JavaScript-এ কম্পাইল করতে ভুলবেন না। আপনি আপনার কোড লিখতে আপনার পছন্দের মডিউল সিস্টেম ব্যবহার করতে পারেন। নিশ্চিত করুন যে আপনার লক্ষ্য Chrome ব্রাউজার দ্বারা সমর্থিত।