Skip to content

Imports

Toutes ces méthodes exposent un constructeur avec la même interface SealdSDK constructeur.

En règle générale, importer le SDK et les plugins directement devrait fonctionner dans la majorité des situations.

javascript
import SealdSDK from '@seald-io/sdk'
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password'
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr'

const seald = SealdSDK({ appId, apiURL, plugins: [SealdSDKPluginSSKSPassword(keyStorageURL), SealdSDKPluginSSKS2MR(keyStorageURL)] })

Vous pouvez cependant vouloir plus de contrôle sur quelle version du SDK est utilisée, sur les polyfills inclus, etc. Ce guide vous explique toutes les options possibles et leurs différences.

WARNING

Quelle que soit la plateforme ou la manière de l'importer, il est fortement déconseillé d'utiliser le Hot-Reload, Hot-Restart, ou toute fonctionnalité similaire, lors du développement avec le SDK Seald, en particulier lors de l'utilisation d'une base de donnée persistante.

Ces techniques lancent une autre instance du code, sans proprement terminer la précédente, ce qui peut entrainer des problèmes de corruption de la base locale.

Il y a 3 manières d'utiliser le Seald-SDK dans votre navigateur, selon vos besoins et l'architecture de votre application web.

Bibliothèque polyfillée

javascript
import SealdSDK from '@seald-io/sdk' // si votre bundler supporte le champ "browser" du package.json (supporté par Webpack 5)

const seald = SealdSDK({ appId, apiURL })
javascript
import SealdSDK from '@seald-io/sdk/browser' // si votre bundler supporte les entry-points personnalisés (supportés par Webpack 5)

const seald = SealdSDK({ appId, apiURL })
javascript
import SealdSDK from '@seald-io/sdk/browser/seald-sdk.polyfilled.js' // import explicite

const seald = SealdSDK({ appId, apiURL })

De la même manière, vous pouvez importer les fichiers suivants pour les plugins :

javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password' // si votre bundler supporte le champ "browser" du package.json (supporté par Webpack 5)

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr' // si votre bundler supporte le champ "browser" du package.json (supporté par Webpack 5)
javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/browser' // si votre bundler supporte les entry-points personnalisés (supportés par Webpack 5)

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/browser' // si votre bundler supporte les entry-points personnalisés (supportés par Webpack 5)
javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/browser/seald-sdk-plugin-ssks-password.polyfilled.js' // import explicite

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/browser/seald-sdk-plugin-ssks-2mr.polyfilled.js' // import explicite

Cette version est déjà empaquetée, transpilée et minifiée pour l'utilisation dans un navigateur web. Elle inclut toutes les bibliothèques, dépendances et polyfills nécessaires à son fonctionnement.

Utilisez cette méthode si vous utilisez un bundler comme webpack, mais que vous ne voulez pas configurer ce bundler pour inclure les polyfills nécessaires.

Bibliothèque

javascript
import SealdSDK from '@seald-io/sdk/browser-library' // si votre bundler supporte les entry-points personnalisés (supportés par Webpack 5)

const seald = SealdSDK({ appId, apiURL })
javascript
import SealdSDK from '@seald-io/sdk/browser/seald-sdk.js' // import explicite

const seald = SealdSDK({ appId, apiURL })

Ceci importe @seald-io/sdk/browser/seald-sdk.js, qui est la version pour le navigateur.

De la même manière, vous pouvez importer les fichiers suivants pour les plugins :

javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/library' // si votre bundler supporte les entry-points personnalisés (supportés par Webpack 5)

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/library' // si votre bundler supporte les entry-points personnalisés (supportés par Webpack 5)
javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/lib/main.js' // import explicite

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/lib/main.js' // import explicite

Utilisez cette méthode si vous utilisez un bundler comme webpack. Pour cela, referez-vous à la section Empaquetage personnalisé et transpilation.

Cette méthode est recommandée, puisqu'elle permet de diminuer la duplication des dépendances et polyfills, et donc minimiser la taille finale de votre application.

Bundle

Copiez le fichier @seald-io/sdk/browser/seald-sdk.browser.js dans votre projet et importez-le via une balise <script>.

De la même manière, vous pouvez copier les fichiers suivants pour les plugins :

  • @seald-io/sdk-plugin-ssks-password/browser/seald-sdk-plugin-ssks-password.browser.js
  • @seald-io/sdk-plugin-ssks-2mr/browser/seald-sdk-plugin-ssks-2mr.browser.js

Par exemple, pour importer le SDK et le plugin SSKS-Password :

html
<html>
<head>
...
<script src="/libraries/seald-sdk.browser.js"></script>
<script src="/libraries/seald-sdk-plugin-ssks-password.browser.js"></script>
<script>
var seald = window.SealdSDK({ appId, apiURL, plugins: [ window.SealdSDKPluginSSKSPassword(keyStorageURL) ] })
</script>
...
</head>
</html>

Cette version est déjà empaquetée, transpilée et minifiée pour l'utilisation dans un navigateur web. Elle inclut toutes les bibliothèques, dépendances et polyfills nécessaires à son fonctionnement.

Elle expose le constructeur Seald SDK dans la variable globale window.SealdSDK.

Les plugins sont exposés dans les variables globales :

  • window.SealdSDKPluginSSKSPassword
  • window.SealdSDKPluginSSKS2MR

Node.js / Electron

javascript
import SealdSDK from '@seald-io/sdk'

const seald = SealdSDK({ appId, apiURL })

Cela importe la version empaquetée pour les projets Node.js.

Elle peut être utilisée pour un serveur NodeJS, une application de bureau en Electron, des tests unitaires, etc.

React-Native

Installation

Le SDK Seald pour react-native a des "peer dependencies" qui doivent être installées séparément :

  • @react-native-async-storage/async-storage (pour les versions 0.11.X et antérieures, il s'agissait du paquet @react-native-community/async-storage)
  • @seald-io/react-native-scrypt (pour les versions 0.23.X et antérieures, il s'agissait du paquet react-native-scrypt)
  • react-native-quick-crypto
  • @craftzdog/react-native-buffer
  • react-native-quick-base64

Vous pouvez les installer avec la commande:

sh
npm i -S @react-native-async-storage/async-storage @seald-io/react-native-scrypt react-native-quick-crypto @craftzdog/react-native-buffer react-native-quick-base64

L'usage de react-native-quick-crypto et de notre SDK impose de définir un polyfill de Buffer spécifique en global. Le plus tôt possible dans votre application, il faut rajouter les lignes suivantes :

js
import { Buffer } from '@craftzdog/react-native-buffer'
global.Buffer = Buffer

Le SDK Seald nécessite également de remplacer certains paquets NodeJS internes par des implémentations React-Native : buffer, crypto et stream. Il est nécessaire de configurer votre bundler pour utiliser des implémentations natives spécifiques qui offrent des performances décentes. Cela peut être fait avec soit le bundler babel, ou le bundler metro, avec les exemples de configuration suivants.

Utilisation avec Metro

Dans le fichier metro.config.js, ajoutez la configuration suivante :

js
config.resolver.resolveRequest = (context, moduleName, platform) => {
  if (moduleName === 'crypto') {
    // when importing crypto, resolve to react-native-quick-crypto
    return context.resolveRequest(
      context,
      'react-native-quick-crypto',
      platform
    )
  }
  if (moduleName === 'buffer') {
    return context.resolveRequest(
      context,
      '@craftzdog/react-native-buffer',
      platform
    )
  }
  if (moduleName === 'stream') {
    return context.resolveRequest(
      context,
      'readable-stream',
      platform
    )
  }
  // otherwise chain to the standard Metro resolver.
  return context.resolveRequest(context, moduleName, platform)
}

Utilisation avec babel-plugin-module-resolver

si vous utilisez babel-plugin-module-resolver, ajoutez la configuration suivante dans le fichier babel.config.js :

js
module.exports = {
  presets: ['module:metro-react-native-babel-preset'],
  plugins: [
    [
      'module-resolver',
      {
        alias: {
          crypto: 'react-native-quick-crypto',
          stream: 'readable-stream',
          buffer: '@craftzdog/react-native-buffer'
        }
      }
    ]
  ]
}

Bundle

La librairie exposée par défaut est une version empaquetée, transpilée et minifiée. Elle est utilisable telle quelle.

javascript
import SealdSDK from '@seald-io/sdk' // si votre bundler supporte le champ "react-native" du package.json (supporté par Metro)

const seald = SealdSDK({ appId, apiURL })
javascript
import SealdSDK from '@seald-io/sdk/react-native' // si votre bundler supporte les entry-points personnalisés (non supporté par Metro)

const seald = SealdSDK({ appId, apiURL })
javascript
import SealdSDK from '@seald-io/sdk/react-native/seald-sdk-react-native.bundle.js' // import explicite

const seald = SealdSDK({ appId, apiURL })

De la même manière, vous pouvez importer les fichiers suivants pour les plugins :

javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password' // si votre bundler supporte le champ "react-native" du package.json (supporté par Metro)

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr' // si votre bundler supporte le champ "react-native" du package.json (supporté par Metro)
javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/react-native' // si votre bundler supporte les entry-points personnalisés (non supporté par Metro)

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/react-native' // si votre bundler supporte les entry-points personnalisés (non supporté par Metro)
javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/react-native/seald-sdk-plugin-ssks-password.bundle.js' // import explicite

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/react-native/seald-sdk-plugin-ssks-2mr.bundle.js' // import explicite

Bibliothèque

Si votre application est elle-même transpilée, vous pouvez importer la librairie source. Cela vous permettra alors d'optimiser la taille de votre application.

javascript
import SealdSDK from '@seald-io/sdk/react-native-library' // si votre bundler supporte les entry-points personnalisés (non supporté par Metro)

const seald = SealdSDK({ appId, apiURL })
javascript
import SealdSDK from '@seald-io/sdk/react-native/react-native/seald-sdk-react-native.js' // import explicite

const seald = SealdSDK({ appId, apiURL })

Cette bibliothèque devra être transpilée pour être utilisée. Pour cela, referez-vous à la section Empaquetage personnalisé et transpilation.

De la même manière, vous pouvez importer les fichiers suivants pour les plugins :

javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/library' // si votre bundler supporte les entry-points personnalisés (non supporté par Metro)

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/library' // si votre bundler supporte les entry-points personnalisés (non supporté par Metro)
javascript
// plugin-ssks-password
import SealdSDKPluginSSKSPassword from '@seald-io/sdk-plugin-ssks-password/lib/main.js' // import explicite

// plugin-ssks-2mr
import SealdSDKPluginSSKS2MR from '@seald-io/sdk-plugin-ssks-2mr/lib/main.js' // import explicite

Empaquetage personnalisé et transpilation

Pour transpiler le SDK, vous aurez besoin d'activer les polyfills des modules internes de NodeJS.

Voici un example de configuration pour le bundler Webpack 5 :

javascript
module.exports = {
  // ... ,
  node: {
    global: true
  },
  resolve: {
    fallback: {
      assert: require.resolve('assert/'),
      fs: false,
      path: require.resolve('path-browserify'),
      events: require.resolve('events/'),
      constants: require.resolve('constants-browserify'),
      os: require.resolve('os-browserify/browser'),
      util: require.resolve('util/'),
      stream: require.resolve('readable-stream'),
      crypto: false
    }
  },
  plugins: [
    new webpack.ProvidePlugin({
      process: 'process/browser',
      Buffer: ['buffer', 'Buffer'],
      setImmediate: ['timers-browserify', 'setImmediate'],
      clearImmediate: ['timers-browserify', 'clearImmediate']
    })
  ]
  // ...
}

Vous pourrez avoir besoin d'installer en devDependencies les paquets assert path-browserify events constants-browserify os-browserify util stream-browserify process buffer timers-browserify.

Pour plus de détails, voir la documentation de webpack.

React-Native

Certaines dépendances du SDK ont des implémentations spécifiques pour React-Native déclarées comme alias dans le champ "react-native" de leur package.json. Ce champ est automatiquement utilisé par metro.

Si vous utilisez un bundler intermédiaire avant d'utiliser metro (comme webpack), vous devrez le spécifier. Vous devrez également considérer comme externes les dépendances natives de React-Native. Dans webpack, il faut ajouter les options suivantes :

js
module.exports = {
  externals: [
    '@craftzdog/react-native-buffer',
    'react-native-quick-crypto',
    'react-native-quick-base64',
    'buffer',
    'crypto',
    'react-native',
    '@seald-io/react-native-scrypt',
    '@react-native-async-storage/async-storage'
  ],
  resolve: {
    aliasFields: ['react-native', 'browser', 'main'],
    fallback: {
      assert: require.resolve('assert/'),
      buffer: '@craftzdog/react-native-buffer',
      fs: false,
      path: require.resolve('path-browserify'),
      events: require.resolve('events/'),
      constants: require.resolve('constants-browserify'),
      os: require.resolve('os-browserify/browser'),
      util: require.resolve('util/'),
      url: require.resolve('url/'),
      stream: require.resolve('stream-browserify')
    }
  }
}