7.2.1 • Published 5 months ago

@notifi-network/notifi-frontend-client v7.2.1

Weekly downloads
-
License
MIT
Repository
github
Last release
5 months ago

Notifi Frontend Client

The Notifi Frontend Client SDK is a JavaScript (Typescript) library that allows you to integrate the Notifi Network into your decentralized application (dApp). Dapp will be able to access Notifi services using client methods.

@notifi/notifi-frontend-client package is not framework specific, it means you can use it with any JavaScript framework like React, Angular, Vue, svelte, etc.

Note: if you are using React, Notifi has a React SDK that is built on top of this SDK, @notifi-network/notifi-react

📥 Installation

npm i @notifi-network/notifi-frontend-client

🪝 Initialization

Instantiate the client object at your dapp to interact with the Notifi core services by providing your notifi Notifi tenant credentials and the user's wallet information.

const tenantId = '<notifi-tenent-id>'; // dappAddress
const env = 'Production'; // or 'Development'
const walletBlockchain = '<the-blockchain-of-your-choice>'; // e.g. 'Ethereum'

const client = newFrontendClient({
  account: {
    // Users wallet credentials (public key, address ... etc)
  },
  tenantId,
  env,
  walletBlockchain,
});

const newUserState = await client.initialize();

Reference:

  • You can register a new tenant to get tenantId (dappAddress) at Notifi Admin Panel for free.
  • The interface of input argument differs depending on the blockchain, see the type doc here

🔏 Authorization

There are two ways to authorize a user with Notifi:

  1. Arbitrary signature authorization
  2. Transaction signature authorization

Arbitrary signature authorization

Authorize users using logIn client method by providing a signMessage callback function.

const signMessage: AptosSignMessageFunction = async (message, nonce) => {
  // Implement your signing logic here ...

  return signature; // string (if the signature is not string format, you will need to convert it to string)
};

const loginResult = await client.logIn({
  walletBlockchain: `the-blockchain-of-your-choice`,
  signMessage,
});

NOTE:

  • The format of the returned signature differs depending on the blockchain, see the type doc here
  • The example of implementing signMessage callback function: notifi-svelte-example

Transaction signature authorization

Authorize users using beginLoginViaTransaction method and completeLoginViaTransaction client method. The beginLoginViaTransaction method will return a nonce that should be appended to the transaction data before signing the transaction. The completeLoginViaTransaction method will take the transaction signature and the nonce to complete the login process. The following examples show how to authorize a user using the transaction signature method on EVM (Ethereum virtual machine) compatible blockchains.

const smartContract = new ethers.Contract(
  `<contract-address>`,
  `<contract-abi>`,
  provider.getSigner(),
);

// Assume the smart contract has an "example" method with one argument uint amount
const amount = ethers.utils.parseUnits('0.1', 'ether');

// Step 1: Get the calldata for the smart contract method call
const calldata = smartContract.interface.encodeFunctionData('example', [
  amount,
]);

// Step 2: Get notifi nonce
const { nonce } = await notifiClient.beginLoginViaTransaction({
  walletBlockchain,
  walletAddress,
});
console.log({ notifiNonce: nonce }); // notifiNonce will be a 32 bytes hex string

// Step 3: Append notifi nonce to the calldata
const txParams = {
  to: smartContract.address,
  data: calldata + nonce.replace('0x', ''),
};

// Step 4: Sign the transaction with new calldata
const { hash } = await provider.getSigner().sendTransaction(txParams);

// Step 5: Use the transaction signature to login to notifi
const notifiLoginResult = await notifiClient.completeLoginViaTransaction({
  walletAddress,
  walletAddress,
  transactionSignature: hash,
  walletBlockchain,
});

IMPORTANT NOTE:

  • Browser extension constraints: Some browser extensions (Metamask ...) do not allow appending additional info to the calldata of particular smart contract method (example: Token contract (ERC20, ERC721 ...etc)). Browser extension (Metamask) will throw Message: Invalid token value; should be exactly xx hex digits long error in this case.

Fetch User Data

The fetchFusionData client method is used to fetch the user's data, including their:

  1. targetGroup: contact informations
  2. alerts: subscribed alerts

NOTE:

📭 Destinations

The ensureTargetGroup client method is used to create a target group for the user's contact information.

Notifi supports the following destination types:

  • Email
  • SMS
  • Telegram
  • Discord
  • More to come
const targetGroup = client.ensureTargetGroup({
  name: 'Default',
  emailAddress: '<user-email>',
  // ... other destination types if needed
});

Reference: ensureTargetGroup

🪢 Topics & Alerts

There are two key concepts of Notifi's notification source: Alert and Topic.

  • Topic is the event allowed to be subscribed (Tenant specific).
  • Alert is the subscription of the Topic (User specific).

Topic is the prototype of the Alert.

Topics

We can get the available topics of the tenant by calling fetchTenantConfig client method.

const id = '<ui-card-config-of-the-tenant>';
const tenantConfig = await client.fetchTenantConfig({
  id,
  type: 'SUBSCRIPTION_CARD',
});
const topics = tenantConfig.fusionEventTopics;

NOTE:

Alerts

We can subscribe users to a topic by creating an alert object by using the ensureFusionAlerts client method.

The following methods are used to get and delete alerts:

  • getAlerts
  • deleteAlert

The full example of getting, deleting, and creating an alert is shown below:

import { resolveObjectArrayRef } from '@notifi-network/notifi-frontend-client';

const topic = topics[0];
const fusionEventDescriptor = topic.fusionEventDescriptor;
const fusionEventMetadataJson = fusionEventDescriptor.metadata;
const fusionEventId = fusionEventDescriptor.id;

if (fusionEventMetadataJson && fusionEventId) {
  const fusionEventMetadata = getFusionEventMetadata(topic);
  const filters = fusionEventMetadata?.filters?.filter(isAlertFilter);
  const fusionFilterOptionsInput: FusionFilterOptions['input'] = {};
  if (filters && filters.length > 0) {
    // NOTE: for now we only consider 1 to 1 relationship (1 filter for 1 topic)
    const userInputParams = filters[0].userInputParams;
    const userInputOptions: UserInputOptions = {};
    userInputParams.forEach((userInputParm) => {
      userInputOptions[userInputParm.name] = userInputParm.defaultValue;
    });
    fusionFilterOptionsInput[filters[0].name] = userInputOptions;
  }
  const filterOptions: FusionFilterOptions = {
    version: 1,
    input: fusionFilterOptionsInput,
  };
  /** Error caught here often caused by incorrect `inputs` format  */
  const subscriptionValueOrRef =
    fusionEventMetadata?.uiConfigOverride?.subscriptionValueOrRef;
  const subscriptionValue = subscriptionValueOrRef
    ? resolveObjectArrayRef('', subscriptionValueOrRef, inputs) // See the related information section for more details
    : null;

  const alertToCreate = fusionEventId;
  const createAlertInputs = [
    {
      fusionEventId: fusionEventId,
      name: alertToCreate,
      targetGroupId,
      subscriptionValue: subscriptionValue?.[0]?.value,
      filterOptions: JSON.stringify(filterOptions),
    },
  ];
}
const existingAlerts = await getAlerts()) ?? [];
const existingAlertNames = alerts.map((alert) => alert.name);

// Alerts are immutable, delete the existing instead
if (existingAlertNames.includes(alerToCreate)) {
  const id = existingAlerts[alerToCreate].id;
  await client.deleteAlert({ id });
}

// Create the alert
await frontendClient.ensureFusionAlerts({ alerts: createAlertInputs });

// Utils
const getFusionEventMetadata = (
  topic: FusionEventTopic,
): FusionEventMetadata | null => {
  const parsedMetadata = JSON.parse(
    topic.fusionEventDescriptor.metadata ?? '{}',
  );
  if (isFusionEventMetadata(parsedMetadata)) {
    return parsedMetadata;
  }
  return null;
};

const isFusionEventMetadata = (
  metadata: unknown,
): metadata is FusionEventMetadata => {
  const metadataToVerify = metadata as any;
  if (typeof metadataToVerify !== 'object' || !metadataToVerify) {
    return false;
  }
  return (
    'filters' in metadataToVerify && Array.isArray(metadataToVerify.filters)
  );
};

Related Information:

  • inputs: it is a concept which is used when a dynamic topic subscription value needs to be adopted. The input is a key-value pair object. The key is the value associated with the Create a new topic section in Admin Portal. The value is the dynamic value that needs to be passed into the topic subscription. The value needs to be an array of InputObject interface. See the doc here

🔔 Notification History

To get notification history, use the getFusionNotificationHistory()

const { nodes, pageInfo } = await client.getFusionNotificationHistory({
  first,
  after,
});

const notifications = nodes.map((node) => {
  return {
    icon: node.detail.icon,
    topicName: node.detail.sourceName,
    message: node.detail.message,
    timestamp: node.createdDate,
  };
});

📝 More examples

  • notifi-dapp-example: A dapp example built with @notifi/notifi-frontend-client and @notifi/notifi-react SDKs.

  • notifi-react-example-v2: React contexts & components library built with @notifi/notifi-frontend-client.

4.0.2-alpha.24

9 months ago

4.0.2-alpha.23

9 months ago

4.0.1

9 months ago

4.0.0

10 months ago

3.1.1-alpha.0

11 months ago

3.1.1-alpha.1

11 months ago

3.1.1-alpha.2

11 months ago

3.0.2-alpha.11

11 months ago

3.0.2-alpha.10

11 months ago

5.0.0

8 months ago

3.1.0

11 months ago

5.1.0

8 months ago

3.0.1

12 months ago

3.0.0

12 months ago

5.2.1

7 months ago

5.2.0

7 months ago

6.0.1

7 months ago

6.0.0

7 months ago

6.0.1-alpha.7

7 months ago

4.1.0

9 months ago

5.1.1-alpha.5

8 months ago

5.2.1-alpha.6

7 months ago

4.0.1-alpha.1

9 months ago

7.2.2-alpha.0

5 months ago

6.0.2-alpha.22

6 months ago

6.0.2-alpha.21

6 months ago

6.0.2-alpha.19

6 months ago

6.0.2-alpha.18

6 months ago

6.0.2-alpha.14

6 months ago

6.0.2-alpha.17

6 months ago

6.0.2-alpha.16

6 months ago

6.0.2-alpha.10

6 months ago

6.0.2-alpha.13

6 months ago

6.0.2-alpha.20

6 months ago

7.0.0

5 months ago

3.0.2-alpha.4

11 months ago

3.0.2-alpha.5

11 months ago

4.0.2-alpha.2

9 months ago

3.0.2-alpha.6

11 months ago

3.0.2-alpha.7

11 months ago

6.0.2-alpha.8

7 months ago

6.0.2-alpha.5

7 months ago

7.1.0

5 months ago

3.0.2-alpha.3

11 months ago

7.2.1

5 months ago

7.2.0

5 months ago

2.2.1-alpha.3

12 months ago

2.2.1-alpha.15

12 months ago

2.2.1-alpha.10

12 months ago

2.2.1-alpha.14

12 months ago

2.2.0

12 months ago

2.1.1-alpha.7

12 months ago

2.1.1-alpha.2

1 year ago

2.1.0

1 year ago

2.0.1-alpha.6

1 year ago

2.0.1-alpha.8

1 year ago

2.0.0

1 year ago

1.1.3-alpha.22

1 year ago

1.1.3-alpha.21

1 year ago

1.1.3-alpha.15

1 year ago

1.1.3-alpha.20

1 year ago

1.1.3-alpha.3

1 year ago

1.1.3-alpha.8

1 year ago

1.1.2

1 year ago

1.1.1-alpha.0

1 year ago

1.1.1-alpha.1

1 year ago

0.91.2

1 year ago

0.91.3

1 year ago

0.92.0

1 year ago

1.1.2-alpha.1

1 year ago

1.1.2-alpha.2

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago

0.91.4-alpha.41

1 year ago

0.91.4-alpha.42

1 year ago

0.91.4-alpha.32

1 year ago

0.91.4-alpha.38

1 year ago

0.91.4-alpha.39

1 year ago

0.91.4-alpha.44

1 year ago

0.91.4-alpha.31

1 year ago

0.91.4-alpha.23

1 year ago

0.91.4-alpha.26

1 year ago

0.91.1

1 year ago

0.90.9-alpha.16

1 year ago

0.90.9-alpha.17

1 year ago

0.91.0

1 year ago

0.90.9-alpha.29

1 year ago

0.90.9-alpha.28

1 year ago

0.90.9-alpha.24

1 year ago

0.90.9-alpha.15

1 year ago

0.90.9-alpha.11

2 years ago

0.90.9-alpha.14

2 years ago

0.91.0-alpha.0

2 years ago

0.90.9-alpha.12

2 years ago

0.90.9-alpha.9

2 years ago

0.90.9-alpha.10

2 years ago

0.90.9-alpha.5

2 years ago

0.90.9-alpha.8

2 years ago

0.83.1-alpha.104

2 years ago

0.90.8

2 years ago

0.90.5

2 years ago

0.90.6

2 years ago

0.90.7

2 years ago

0.90.2

2 years ago

0.90.4

2 years ago

0.90.1

2 years ago

0.90.0

2 years ago

0.89.4

2 years ago

0.89.1-alpha.1

2 years ago

0.89.0

2 years ago

0.88.3-alpha.2

2 years ago

0.88.2-alpha.2

2 years ago

0.88.2-alpha.1

2 years ago

0.88.2

2 years ago

0.88.2-alpha.0

2 years ago

0.88.1

2 years ago

0.88.1-alpha.2

2 years ago

0.88.1-alpha.3

2 years ago

0.81.0

2 years ago

0.82.0

2 years ago

0.82.1

2 years ago

0.79.0

2 years ago

0.83.1-alpha.1

2 years ago

0.87.0

2 years ago

0.76.0

2 years ago

0.88.0

2 years ago

0.87.1-alpha.4

2 years ago

0.87.1-alpha.3

2 years ago

0.80.0

2 years ago

0.77.0

2 years ago

0.85.0

2 years ago

0.85.1

2 years ago

0.86.2

2 years ago

0.81.1-alpha.0

2 years ago

0.86.0

2 years ago

0.86.1

2 years ago

0.75.2

2 years ago

0.75.1

2 years ago

0.87.1

2 years ago

0.83.0

2 years ago

0.82.1-alpha.0

2 years ago

0.75.2-alpha.0

2 years ago

0.86.2-alpha.4

2 years ago

0.84.0

2 years ago

0.85.7

2 years ago

0.85.3

2 years ago

0.85.4

2 years ago

0.85.5

2 years ago

0.85.6

2 years ago

0.75.0

2 years ago

0.69.1-alpha.0

2 years ago

0.70.0

2 years ago

0.67.0

2 years ago

0.68.1-alpha.5

2 years ago

0.68.1-alpha.4

2 years ago

0.73.2-alpha.4

2 years ago

0.73.2-alpha.3

2 years ago

0.73.2-alpha.2

2 years ago

0.73.2-alpha.1

2 years ago

0.71.0

2 years ago

0.68.0

2 years ago

0.73.3-alpha.4

2 years ago

0.73.3-alpha.5

2 years ago

0.65.0

2 years ago

0.66.0

2 years ago

0.73.1-alpha.0

2 years ago

0.74.0

2 years ago

0.74.1

2 years ago

0.72.0

2 years ago

0.69.0

2 years ago

0.71.1-alpha.1

2 years ago

0.73.4

2 years ago

0.73.1

2 years ago

0.73.0

2 years ago

0.72.1-alpha.0

2 years ago

0.73.2

2 years ago

0.65.1-alpha.11

2 years ago

0.65.1-alpha.12

2 years ago

0.72.1-alpha.1

2 years ago

0.63.1-alpha.6

2 years ago

0.63.1-alpha.4

2 years ago

0.61.2-alpha.0

3 years ago

0.55.0

3 years ago

0.59.2-alpha.3

3 years ago

0.59.2-alpha.0

3 years ago

0.59.2-alpha.2

3 years ago

0.56.0

3 years ago

0.58.2-alpha.2

3 years ago

0.58.2-alpha.4

3 years ago

0.58.2-alpha.5

3 years ago

0.58.2-alpha.6

3 years ago

0.64.0

2 years ago

0.57.5-alpha.0

3 years ago

0.57.5-alpha.1

3 years ago

0.57.5-alpha.2

3 years ago

0.61.4-alpha.0

3 years ago

0.54.0

3 years ago

0.59.2

3 years ago

0.59.3

3 years ago

0.59.0

3 years ago

0.59.1

3 years ago

0.61.9-alpha.9

3 years ago

0.59.8

3 years ago

0.59.6

3 years ago

0.59.7

3 years ago

0.59.4

3 years ago

0.59.5

3 years ago

0.61.9-alpha.2

3 years ago

0.61.9-alpha.3

3 years ago

0.61.9-alpha.8

3 years ago

0.61.9-alpha.7

3 years ago

0.63.0

2 years ago

0.61.1-alpha.0

3 years ago

0.60.0

3 years ago

0.57.4

3 years ago

0.57.2

3 years ago

0.57.3

3 years ago

0.54.1-alpha.0

3 years ago

0.57.0

3 years ago

0.54.1-alpha.1

3 years ago

0.57.1

3 years ago

0.59.4-alpha.0

3 years ago

0.59.4-alpha.4

3 years ago

0.59.4-alpha.3

3 years ago

0.59.4-alpha.1

3 years ago

0.61.6

3 years ago

0.61.5

3 years ago

0.61.8

3 years ago

0.61.2

3 years ago

0.61.1

3 years ago

0.61.4

3 years ago

0.61.3

3 years ago

0.61.0

3 years ago

0.58.1

3 years ago

0.58.0

3 years ago

0.59.4-alpha.6

3 years ago

0.59.4-alpha.5

3 years ago

0.49.2-alpha.3

3 years ago

0.49.2-alpha.2

3 years ago

0.49.2-alpha.1

3 years ago

0.49.2-alpha.0

3 years ago

0.51.4

3 years ago

0.51.2

3 years ago

0.51.0

3 years ago

0.51.1

3 years ago

0.51.3-alpha.0

3 years ago

0.51.5-alpha.4

3 years ago

0.51.5-alpha.2

3 years ago

0.51.5-alpha.3

3 years ago

0.49.3-alpha.2

3 years ago

0.49.3-alpha.4

3 years ago

0.49.3-alpha.3

3 years ago

0.52.0

3 years ago

0.49.3-alpha.6

3 years ago

0.49.1

3 years ago

0.49.3-alpha.5

3 years ago

0.49.0

3 years ago

0.53.0

3 years ago

0.48.1-alpha.7

3 years ago

0.48.1-alpha.6

3 years ago

0.48.1-alpha.2

3 years ago

0.50.0

3 years ago

0.43.1-alpha.12

3 years ago

0.43.1-alpha.10

3 years ago

0.43.1-alpha.11

3 years ago

0.43.0

3 years ago

0.44.1-alpha.11

3 years ago

0.44.1-alpha.13

3 years ago

0.44.1-alpha.14

3 years ago

0.43.1-alpha.9

3 years ago

0.43.1-alpha.7

3 years ago

0.43.1-alpha.6

3 years ago

0.48.0

3 years ago

0.44.0

3 years ago

0.44.1-alpha.15

3 years ago

0.44.1-alpha.16

3 years ago

0.44.1-alpha.17

3 years ago

0.45.1-alpha.8

3 years ago

0.45.1-alpha.9

3 years ago

0.45.0

3 years ago

0.45.1-alpha.1

3 years ago

0.46.2

3 years ago

0.47.1-alpha.0

3 years ago

0.46.1

3 years ago

0.45.1-alpha.12

3 years ago

0.45.1-alpha.10

3 years ago

0.47.0

3 years ago

0.42.2-alpha.27

3 years ago

0.42.2-alpha.28

3 years ago

0.42.2-alpha.29

3 years ago

0.42.2-alpha.9

3 years ago

0.42.2-alpha.5

3 years ago

0.42.2-alpha.30

3 years ago

0.42.2-alpha.12

3 years ago

0.42.2-alpha.18

3 years ago

0.42.2-alpha.19

3 years ago

0.42.2-alpha.21

3 years ago

0.42.2-alpha.1

3 years ago

0.42.2-alpha.2

3 years ago

0.42.2-alpha.0

3 years ago

0.38.1-alpha.0

3 years ago

0.38.1-alpha.1

3 years ago

0.41.0

3 years ago

0.38.1-alpha.2

3 years ago

0.38.1-alpha.4

3 years ago

0.38.2

3 years ago

0.38.0

3 years ago

0.36.0

3 years ago

0.38.3-alpha.0

3 years ago

0.41.2-alpha.9

3 years ago

0.41.2-alpha.8

3 years ago

0.41.1-alpha.11

3 years ago

0.41.1-alpha.10

3 years ago

0.38.4-alpha.4

3 years ago

0.35.1-alpha.2

3 years ago

0.35.1-alpha.3

3 years ago

0.35.1-alpha.0

3 years ago

0.35.1-alpha.1

3 years ago

0.41.2-alpha.2

3 years ago

0.39.1-alpha.1

3 years ago

0.40.1-alpha.2

3 years ago

0.40.1-alpha.3

3 years ago

0.38.4-alpha.20

3 years ago

0.36.1-alpha.3

3 years ago

0.36.1-alpha.4

3 years ago

0.36.1-alpha.1

3 years ago

0.36.1-alpha.2

3 years ago

0.42.0

3 years ago

0.42.1

3 years ago

0.42.1-alpha.0

3 years ago

0.41.2-alpha.10

3 years ago

0.40.0

3 years ago

0.39.1-alpha.6

3 years ago

0.36.1-alpha.0

3 years ago

0.39.0

3 years ago

0.37.2

3 years ago

0.37.1

3 years ago

0.38.4-alpha.32

3 years ago

0.38.4-alpha.33

3 years ago

0.38.4-alpha.3

3 years ago

0.41.1-alpha.9

3 years ago

0.41.1-alpha.7

3 years ago

0.41.1-alpha.6

3 years ago

0.41.1-alpha.5

3 years ago

0.41.1-alpha.4

3 years ago

0.41.1-alpha.3

3 years ago

0.41.1-alpha.2

3 years ago

0.35.0

3 years ago

0.34.1-alpha.7

3 years ago

0.34.1-alpha.6

3 years ago

0.34.1-alpha.5

3 years ago

0.34.1-alpha.2

3 years ago

0.34.1-alpha.1

3 years ago

0.34.1-alpha.0

3 years ago

0.34.0

3 years ago

0.33.0

3 years ago

0.32.1-alpha.40

3 years ago

0.32.1-alpha.39

3 years ago

0.32.1-alpha.38

3 years ago

0.32.1-alpha.37

3 years ago

0.32.1-alpha.36

3 years ago

0.32.1-alpha.34

3 years ago

0.32.1-alpha.33

3 years ago

0.32.1-alpha.32

3 years ago

0.32.1-alpha.31

3 years ago

0.32.1-alpha.30

3 years ago

0.32.1-alpha.29

3 years ago

0.32.1-alpha.28

3 years ago

0.32.1-alpha.26

3 years ago

0.32.1-alpha.25

3 years ago

0.32.1-alpha.24

3 years ago

0.32.1-alpha.23

3 years ago

0.32.1-alpha.22

3 years ago

0.32.1-alpha.21

3 years ago

0.32.1-alpha.19

3 years ago

0.32.1-alpha.17

3 years ago

0.32.1-alpha.16

3 years ago

0.32.1-alpha.15

3 years ago

0.32.1-alpha.14

3 years ago

0.32.1-alpha.11

3 years ago

0.32.1-alpha.10

3 years ago

0.32.0

3 years ago

0.31.1-alpha.25

3 years ago

0.31.1-alpha.24

3 years ago

0.31.1-alpha.23

3 years ago

0.31.1-alpha.22

3 years ago

0.31.1-alpha.21

3 years ago

0.31.1-alpha.20

3 years ago

0.31.1-alpha.19

3 years ago