Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dynamic Imports of SDK Modules #260

Merged
merged 20 commits into from
Dec 17, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,6 @@
"build-dev": "webpack --config webpack.dev.js",
"test": "jest --config test/jest.config.js",
"testCoverage": "NODE_ENV=test jest --config test/jest.config.js",
"postinstall": "npm update @firebolt-js/manage-sdk",
"format": "prettier --write \"**/*.js\"",
"lint": "eslint ."
},
Expand Down
96 changes: 27 additions & 69 deletions src/FireboltExampleInvoker.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,34 +16,40 @@
* SPDX-License-Identifier: Apache-2.0
*/

import { Accessibility, Account, Advertising, Authentication, Capabilities, Device, Discovery, Keyboard, Lifecycle, Localization, Metrics, Profile, Parameters, SecondScreen, SecureStorage } from '@firebolt-js/sdk';
import {
Advertising as ManageAdvertising,
AcknowledgeChallenge,
Device as ManageDevice,
Wifi,
Account as ManageAccount,
ClosedCaptions,
Keyboard as ManageKeyboard,
Localization as ManageLocalization,
PinChallenge,
Privacy,
VoiceGuidance,
UserGrants,
Metrics as ManageMetrics,
SecureStorage as ManageSecureStorage,
Discovery as ManageDiscovery,
AudioDescriptions,
HDMIInput,
} from '@firebolt-js/manage-sdk';
import { Content } from '@firebolt-js/discovery-sdk';
import * as CoreSDK from '@firebolt-js/sdk';
import * as ManageSDK from '@firebolt-js/manage-sdk';
import FireboltSdkManager from './utils/FireboltSdkManager';
import DiscoveryInvoker from './invokers/DiscoveryInvoker';
const discoveryInvoker = new DiscoveryInvoker();
const logger = require('./utils/Logger')('FireboltExampleInvoker.js');
import { removeSetInMethodName } from './utils/Utils';
import { eventEmitter } from './Toast';
import { CONSTANTS } from './constant';

/**
* Dynamically check if the Discovery SDK is available as a dependency.
* If available, require it. Otherwise, log a warning.
*/
const dependencies = DEPENDENCIES; // Injected by Webpack DefinePlugin
let DiscoverySDK;

if (dependencies.hasOwnProperty('@firebolt-js/discovery-sdk')) {
try {
DiscoverySDK = require('@firebolt-js/discovery-sdk');
} catch (error) {
console.warn('DiscoverySDK is not available:', error);
}
}
neeradanelxsi marked this conversation as resolved.
Show resolved Hide resolved

// Initialize the Firebolt SDK Module Loader
const sdkManager = new FireboltSdkManager(CoreSDK, ManageSDK, DiscoverySDK, dependencies);

// Dynamically generate the module map based on the imported SDKs
const moduleMap = sdkManager.generateModuleMap();

// Export the dynamically created module map
export const MODULE_MAP = moduleMap;

// Commenting the below APIs as they have been deprecated from discovery sdk , can be uncommented when added as ripple-rpc APIs in future ticket
const MAP = {
'discovery.purchasedContent': discoveryInvoker.purchasedContent.bind(discoveryInvoker),
Expand All @@ -52,54 +58,6 @@ const MAP = {
// 'content.entity': discoveryInvoker.getEntityInfo.bind(discoveryInvoker),
};

const CORE_MODULE_MAP = {
accessibility: Accessibility,
account: Account,
advertising: Advertising,
authentication: Authentication,
capabilities: Capabilities,
device: Device,
discovery: Discovery,
keyboard: Keyboard,
lifecycle: Lifecycle,
localization: Localization,
metrics: Metrics,
profile: Profile,
parameters: Parameters,
secondscreen: SecondScreen,
securestorage: SecureStorage,
};

const MANAGE_MODULE_MAP = {
advertising: ManageAdvertising,
acknowledgechallenge: AcknowledgeChallenge,
device: ManageDevice,
wifi: Wifi,
account: ManageAccount,
closedcaptions: ClosedCaptions,
keyboard: ManageKeyboard,
pinchallenge: PinChallenge,
privacy: Privacy,
voiceguidance: VoiceGuidance,
localization: ManageLocalization,
usergrants: UserGrants,
metrics: ManageMetrics,
securestorage: ManageSecureStorage,
discovery: ManageDiscovery,
audiodescriptions: AudioDescriptions,
hdmiinput: HDMIInput,
};

const DISCOVERY_MODULE_MAP = {
content: Content,
};

export const MODULE_MAP = {
core: CORE_MODULE_MAP,
manage: MANAGE_MODULE_MAP,
discovery: DISCOVERY_MODULE_MAP,
};

// importing additional invoker which has external sdk's being exported and adding those modules in the MODULE_MAP
try {
const additionalInvoker = require('../plugins/FireboltExtensionInvoker').default;
Expand Down
55 changes: 25 additions & 30 deletions src/constant.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,30 @@
*/

import CONFIG_CONSTANTS from 'config';
import CORE_OPEN_RPC from '@firebolt-js/sdk/dist/firebolt-core-open-rpc';
import MANAGE_OPEN_RPC from '@firebolt-js/manage-sdk/dist/firebolt-manage-open-rpc';
import DISCOVERY_OPEN_RPC from '@firebolt-js/discovery-sdk/dist/firebolt-discovery-open-rpc';
import * as CoreSDK from '@firebolt-js/sdk';
import * as ManageSDK from '@firebolt-js/manage-sdk';
import FireboltSdkManager from './utils/FireboltSdkManager';

/**
* Dynamically check if the Discovery SDK is available as a dependency.
* If available, require it. Otherwise, log a warning.
*/
const dependencies = DEPENDENCIES; // Injected by Webpack DefinePlugin
let DiscoverySDK;

if (dependencies.hasOwnProperty('@firebolt-js/discovery-sdk')) {
try {
DiscoverySDK = require('@firebolt-js/discovery-sdk');
} catch (error) {
console.warn('DiscoverySDK is not available:', error);
}
}

// Initialize the Firebolt SDK Module Loader
const sdkManager = new FireboltSdkManager(CoreSDK, ManageSDK, DiscoverySDK, dependencies);

const defaultSdks = sdkManager.generateDefaultSdkConstants();

export const CONSTANTS = {
ALL_SDKS: 'ALL SDKS',
SDK: 'SDK',
Expand Down Expand Up @@ -141,35 +162,9 @@ export const CONSTANTS = {
EXCLUDED_METHODS_FOR_SDK: [],
EXCLUDED_METHODS_FOR_TRANSPORT: [],
REGISTERPROVIDER: 'registerprovider',
defaultSDKs: defaultSdks,
INVOKEPROVIDER: 'invokeProvider',
INVOKEMANAGER: 'invokeManager',
defaultSDKs: [
{
name: 'Core',
openRpc: CORE_OPEN_RPC,
validation: function () {
return !(process.env.MF_VALUE && !process.env.MOCKOS);
},
unavailableMessage: 'MockOs is not running',
},
{
name: 'Manage',
openRpc: MANAGE_OPEN_RPC,
validation: function () {
return !(process.env.MF_VALUE && !process.env.MOCKOS);
},
unavailableMessage: 'MockOs is not running',
},
{
name: 'Discovery',
openRpc: DISCOVERY_OPEN_RPC,
validation: function () {
return !(process.env.MF_VALUE && !process.env.MOCKOS);
},
unavailableMessage: 'MockOs is not running',
},
],

additionalSDKs: [],
EXCLUDED_METHODS_FOR_MFOS: [],
...CONFIG_CONSTANTS,
Expand Down
Loading
Loading