Enlaces seguros para Node.js con Rust y WebAssembly

Rate this content
Bookmark
Slides

Esta charla te enseñará cómo escribir módulos de Node.js críticos para el rendimiento sin la carga de distribuir artefactos dependientes de la plataforma y usar la cadena de herramientas C/C++. Descubrirás cómo integrar sin problemas código Rust en tu aplicación Node.js + TypeScript utilizando WebAssembly. También aprenderás cómo evitar los problemas típicos de serialización de WebAssembly y entenderás cuándo otras alternativas como Neon o Napi.rs son preferibles. Juntos, cruzaremos el puente del lenguaje entre Rust y Node.js mientras preservamos la familiaridad de la experiencia de desarrollo que estás acostumbrado.

FAQ

WebAssembly, o WASM, es una abstracción de bajo nivel para la CPU que permite ejecutar bytecode rápido y compacto diseñado para lograr una velocidad cercana a la nativa. Es útil porque permite compilar código una vez y ejecutarlo en diferentes plataformas sin degradación del rendimiento, optimizando el inicio rápido y una huella de memoria pequeña.

Desde la versión 8, Node.js soporta WebAssembly, permitiendo importar un módulo WASM exactamente como se importaría un paquete estándar de npm.

Rust es popular en el contexto de WebAssembly debido a su capacidad para generar enlaces seguros y tipos, y por ser votado consistentemente como el mejor lenguaje para trabajar con WebAssembly, facilitando la creación de módulos nativos para Node.js.

Wasm.bindgen es una herramienta y biblioteca en Rust que ayuda a conectar bits de código Rust con JavaScript, permitiendo la generación de enlaces de Node.js y TypeScript para módulos WASM. Se utiliza para generar automáticamente tipos y facilitar la integración con Node.js.

Existen limitaciones en el soporte de estructuras de datos complejas y tipos, como las variantes de enumeración y las uniones discriminadas, que no son completamente compatibles con WebAssembly. Esto puede resultar en una experiencia de desarrollo menos ergonómica y segura para los desarrolladores de TypeScript.

Tspy es una herramienta que ayuda a generar enlaces seguros de tipos y ergonómicos entre Rust y TypeScript. Ofrece soporte completo para estructuras de datos y tipos, eliminando la necesidad de conversiones manuales y mejorando la integración y desarrollo con TypeScript.

Alberto Schiabel
Alberto Schiabel
22 min
17 Apr, 2023

Comments

Sign in or register to post your comment.

Video Summary and Transcription

Esta charla explora los enlaces de TypeScript para NodeJS con Rust y WebAssembly, proporcionando un enfoque alternativo para crear módulos nativos de NodeJS y generar automáticamente tipos. Se adentra en el uso de WebAssembly y Rust para módulos de TypeScript, mostrando cómo se pueden definir e importar funciones Rust utilizando la biblioteca wasm.bindgen. La charla también destaca los desafíos de la conversión de cadenas entre Rust y JavaScript, las limitaciones de soporte de los tipos de datos Rust en JavaScript y la integración perfecta de las funciones Rust en aplicaciones TypeScript utilizando tspy. Concluye con la recomendación de TSFI para enlaces seguros y muestra su uso en un motor de búsqueda de texto completo basado en TypeScript con soporte de WebAssembly.

1. Introducción

Short description:

Esto es TypeScript Bindings para NodeJS con Rust y WebAssembly. Buscaremos un enfoque alternativo y más fácil para crear módulos nativos de NodeJS, al mismo tiempo que generamos automáticamente los tipos para ellos.

Hola a todos, y gracias a Node Congress por tenerme aquí. Esto es TypeScript Bindings para NodeJS con Rust y WebAssembly. Buscaremos un enfoque alternativo y más fácil para crear módulos nativos de NodeJS, al mismo tiempo que generamos automáticamente los tipos para ellos.

Un poco sobre mí. Soy Alberto Schibel. Soy de Venecia, Italia. Soy un ingeniero de software en Prisma donde he portado varios módulos de Rust a WebAssembly. También soy consultor y trabajo con NodeJS, TypeScript y Rust. Puedes encontrarme en línea en j.com.io. También puedes encontrar las diapositivas

2. WebAssembly y Rust para Módulos de TypeScript

Short description:

WebAssembly, o WASM, es una abstracción de bajo nivel para la CPU en la que se ejecuta tu código. Es un bytecode rápido y compacto diseñado para lograr una velocidad cercana a la nativa y optimizado para un inicio rápido y una huella de memoria pequeña. Es un objetivo de compilación portátil para muchos lenguajes, incluido Rust. Rust es consistentemente votado como el mejor lenguaje para WebAssembly. Veamos cómo podemos crear módulos de TypeScript a partir de él.

para esta charla en mi página de GitHub. Entonces, el elefante en la habitación, ¿qué es WebAssembly y cómo es útil? Bueno, WebAssembly, o WASM, es básicamente una abstracción de bajo nivel para la CPU en la que se ejecuta tu código. Es un bytecode rápido y compacto en el sentido de que es un formato binario portátil para una máquina virtual que modela las operaciones de carga y almacenamiento de números en la memoria lineal. Está diseñado para lograr una velocidad cercana a la nativa y también está optimizado para un inicio rápido y una huella de memoria pequeña. Fue creado por los proveedores de navegadores para portar código C++ a la web sin degradación del rendimiento y ahora es un objetivo de compilación portátil para muchos lenguajes, incluidos Rust, Go y muchos otros. Eso significa que puedes compilar tu código a WASM una vez y luego ejecutar el mismo artefacto compilado en diferentes plataformas. Por ejemplo, Node.js admite WebAssembly desde la versión 8 y ahora puedes importar un módulo WASM exactamente como importarías un paquete estándar de npm. Y ¿por qué es útil un único objetivo de compilación portátil? Considera Node.js, un popular complemento NAPI que compila estilos SAS a CSS. Para admitir múltiples configuraciones del sistema, arquitecturas e incluso versiones de Node.js, esta biblioteca debe compilarse por separado para cada una de estas configuraciones. Esto significa 35 objetivos de compilación diferentes y hace que cada nueva implementación sea una tarea que consume tiempo y recursos. Aquellos de ustedes que usan Prisma probablemente sepan que estamos en una situación similar con el CLI de TypeScript y una biblioteca que descarga algunos binarios compilados de Rust bajo demanda. Esto es lo que nos hizo considerar WebAssembly y adoptarlo tanto como para simplificar nuestro proceso de implementación. Y si alguna vez has intentado escribir complementos nativos de Node.js, probablemente sepas que no es un proceso sencillo. A veces, no jib falla con mensajes de error crípticos y, francamente, las herramientas necesarias para construir e importar módulos de C++ no son tan amigables para los humanos como lo que los desarrolladores de Node.js están acostumbrados a utilizar. Entonces, esta es quizás una de las principales razones por las que Rust es consistentemente votado como el mejor lenguaje para WebAssembly. Entonces, veamos cómo podemos crear los módulos de TypeScript a partir de él. Y para aquellos de ustedes que son nuevos en Rust, definamos algunos conceptos básicos, ¿de acuerdo? Entonces, cualquier cosa que uses un paquete de json para, lo colocarías en un archivo cargo.toml en un proyecto de Rust. Lo que normalmente llamas paquetes de npm son cajas en Rust y operas con ellas a través del comando cargo CLI. Por ejemplo, para compilar código Rust, usarías el comando cargo build y especificarías el objetivo de compilación. En nuestro caso, es Wasm 32 desconocido, desconocido. Utiliza un espacio de direccionamiento de 32 bits y no está vinculado a ningún proveedor de sistema operativo o arquitectura de CPU en particular. Si queremos mover más que solo datos numéricos a través del puente de WebAssembly, necesitaremos una herramienta de enlace. Es tanto un CLI como una biblioteca de Rust. Cuando lo instalas, debes especificar una versión particular, porque aún no sigue la versión semántica. Esto significa que la versión que especificas en tu archivo cargo.toml debe coincidir con la versión de Wasm que tienes instalada en tu máquina. Además, para admitir WebAssembly, debes marcar tu tipo de caja como c.lib. Esto le indicará a Rust que compile tu código como una biblioteca dinámica que puede ser cargada por un runtime compatible con C, como Node.js. Entonces, compilar Rust a WebAssembly es un proceso de dos pasos. Primero, debes ejecutar cargo.build para crear un artefacto de WebAssembly compilado, que tendrá la extensión .wasm, y luego agregarás wasm.bindgen para generar los enlaces de Node.js y TypeScript que utilizarás para importar el módulo wasm compilado. Por supuesto, si wasm.bindgen admitiera todas las estructuras de datos comúnmente utilizadas de Rust y las convenciones de TypeScript, esta charla ya habría terminado, y claramente ese no es el caso. Entonces veamos cómo podemos solucionar esto.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Utilizando Rust desde Vue con WebAssembly
Vue.js London Live 2021Vue.js London Live 2021
8 min
Utilizando Rust desde Vue con WebAssembly
Top Content
Rust es un nuevo lenguaje para escribir código de alto rendimiento, que puede ser compilado a WebAssembly, y ejecutado dentro del navegador. En esta charla se te guiará sobre cómo puedes integrar Rust, dentro de una aplicación Vue, de una manera que es sencilla y fácil. Con ejemplos de cómo interactuar con Rust desde JavaScript, y algunas de las trampas a tener en cuenta.
TypeScript y React: Secretos de un matrimonio feliz
React Advanced Conference 2022React Advanced Conference 2022
21 min
TypeScript y React: Secretos de un matrimonio feliz
Top Content
TypeScript y React son inseparables. ¿Cuál es el secreto de su exitosa unión? Bastante código extrañamente extraño. Aprende por qué useRef siempre se siente extraño, cómo manejar los genéricos en los hooks personalizados y cómo los tipos de unión pueden transformar tus componentes.
Haciendo JavaScript en WebAssembly Rápido
JSNation Live 2021JSNation Live 2021
29 min
Haciendo JavaScript en WebAssembly Rápido
Top Content
JavaScript en el navegador se ejecuta muchas veces más rápido de lo que lo hacía hace dos décadas. Y eso sucedió porque los proveedores de navegadores pasaron ese tiempo trabajando en intensivas optimizaciones de rendimiento en sus motores JavaScript.Debido a este trabajo de optimización, JavaScript ahora se está ejecutando en muchos lugares además del navegador. Pero todavía hay algunos entornos donde los motores JS no pueden aplicar esas optimizaciones de la manera correcta para hacer las cosas rápidas.Estamos trabajando para resolver esto, comenzando una nueva ola de trabajo de optimización de JavaScript. Estamos mejorando el rendimiento de JavaScript para entornos completamente diferentes, donde se aplican reglas diferentes. Y esto es posible gracias a WebAssembly. En esta charla, explicaré cómo funciona todo esto y qué vendrá a continuación.
Los tipos más útiles de React
React Day Berlin 2023React Day Berlin 2023
21 min
Los tipos más útiles de React
Top Content
No pensamos en React como si tuviera sus propios tipos. Pero los tipos de React son una parte fundamental del marco de trabajo - supervisados por el equipo de React, y coordinados con las principales lanzamientos de React.En esta charla de codificación en vivo, veremos todos los tipos que te has estado perdiendo. ¿Cómo obtienes el tipo de props de un componente? ¿Cómo sabes qué ref toma un componente? ¿Deberías usar React.FC? ¿Y qué pasa con JSX.Element?Te irás con un montón de ideas emocionantes para llevar a tus aplicaciones de React, y esperamos que con una nueva apreciación por las maravillas de React y TypeScript trabajando juntos.
Es una jungla ahí fuera: ¿Qué está pasando realmente dentro de tu carpeta Node_Modules?
Node Congress 2022Node Congress 2022
26 min
Es una jungla ahí fuera: ¿Qué está pasando realmente dentro de tu carpeta Node_Modules?
Top Content
¿Sabes qué está pasando realmente en tu carpeta node_modules? Los ataques a la cadena de suministro de software han explotado en los últimos 12 meses y solo están acelerándose en 2022 y más allá. Profundizaremos en ejemplos de recientes ataques a la cadena de suministro y qué pasos concretos puedes tomar para proteger a tu equipo de esta amenaza emergente.
Puedes consultar las diapositivas de la charla de Feross aquí.
Hacia una Biblioteca Estándar para Runtimes de JavaScript
Node Congress 2022Node Congress 2022
34 min
Hacia una Biblioteca Estándar para Runtimes de JavaScript
Top Content
Puedes revisar las diapositivas de la charla de James aquí.

Workshops on related topic

React, TypeScript y TDD
React Advanced Conference 2021React Advanced Conference 2021
174 min
React, TypeScript y TDD
Top Content
Featured WorkshopFree
Paul Everitt
Paul Everitt
ReactJS es extremadamente popular y, por lo tanto, ampliamente soportado. TypeScript está ganando popularidad y, por lo tanto, cada vez más soportado.

¿Los dos juntos? No tanto. Dado que ambos cambian rápidamente, es difícil encontrar materiales de aprendizaje precisos.

¿React+TypeScript, con los IDEs de JetBrains? Esa combinación de tres partes es el tema de esta serie. Mostraremos un poco sobre mucho. Es decir, los pasos clave para ser productivo, en el IDE, para proyectos de React utilizando TypeScript. En el camino, mostraremos el desarrollo guiado por pruebas y enfatizaremos consejos y trucos en el IDE.
Mejores Prácticas y Consejos Avanzados de TypeScript para Desarrolladores de React
React Advanced Conference 2022React Advanced Conference 2022
148 min
Mejores Prácticas y Consejos Avanzados de TypeScript para Desarrolladores de React
Top Content
Featured Workshop
Maurice de Beijer
Maurice de Beijer
¿Eres un desarrollador de React tratando de obtener los máximos beneficios de TypeScript? Entonces esta es la masterclass para ti.En esta masterclass interactiva, comenzaremos desde lo básico y examinaremos los pros y contras de las diferentes formas en que puedes declarar componentes de React usando TypeScript. Después de eso, pasaremos a conceptos más avanzados donde iremos más allá de la configuración estricta de TypeScript. Aprenderás cuándo usar tipos como any, unknown y never. Exploraremos el uso de predicados de tipo, guardias y comprobación exhaustiva. Aprenderás sobre los tipos mapeados incorporados, así como cómo crear tus propias utilidades de mapa de tipo nuevo. Y comenzaremos a programar en el sistema de tipos de TypeScript usando tipos condicionales e inferencia de tipos.
Consejos y Trucos Profundos de TypeScript
Node Congress 2024Node Congress 2024
83 min
Consejos y Trucos Profundos de TypeScript
Top Content
Workshop
Josh Goldberg
Josh Goldberg
TypeScript tiene un sistema de tipos poderoso con todo tipo de características sofisticadas para representar estados de JavaScript salvajes y extravagantes. Pero la sintaxis para hacerlo no siempre es sencilla, y los mensajes de error no siempre son precisos al decirte qué está mal. Vamos a profundizar en cómo funcionan muchas de las características más poderosas de TypeScript, qué tipos de problemas del mundo real resuelven, y cómo dominar el sistema de tipos para que puedas escribir código TypeScript verdaderamente excelente.
Masterclass de Node.js
Node Congress 2023Node Congress 2023
109 min
Masterclass de Node.js
Top Content
Workshop
Matteo Collina
Matteo Collina
¿Alguna vez has tenido dificultades para diseñar y estructurar tus aplicaciones Node.js? Construir aplicaciones que estén bien organizadas, sean probables y extensibles no siempre es fácil. A menudo puede resultar ser mucho más complicado de lo que esperas. En este evento en vivo, Matteo te mostrará cómo construye aplicaciones Node.js desde cero. Aprenderás cómo aborda el diseño de aplicaciones y las filosofías que aplica para crear aplicaciones modulares, mantenibles y efectivas.

Nivel: intermedio
Construye y Despliega un Backend con Fastify y Platformatic
JSNation 2023JSNation 2023
104 min
Construye y Despliega un Backend con Fastify y Platformatic
WorkshopFree
Matteo Collina
Matteo Collina
Platformatic te permite desarrollar rápidamente APIs GraphQL y REST con un esfuerzo mínimo. La mejor parte es que también te permite aprovechar todo el potencial de Node.js y Fastify cuando lo necesites. Puedes personalizar completamente una aplicación de Platformatic escribiendo tus propias características y complementos adicionales. En el masterclass, cubriremos tanto nuestros módulos de código abierto como nuestra oferta en la nube:- Platformatic OSS (open-source software) — Herramientas y bibliotecas para construir rápidamente aplicaciones robustas con Node.js (https://oss.platformatic.dev/).- Platformatic Cloud (actualmente en beta) — Nuestra plataforma de alojamiento que incluye características como aplicaciones de vista previa, métricas integradas e integración con tu flujo de Git (https://platformatic.dev/).
En este masterclass aprenderás cómo desarrollar APIs con Fastify y desplegarlas en la nube de Platformatic.
0 a Auth en una Hora Usando NodeJS SDK
Node Congress 2023Node Congress 2023
63 min
0 a Auth en una Hora Usando NodeJS SDK
WorkshopFree
Asaf Shen
Asaf Shen
La autenticación sin contraseña puede parecer compleja, pero es fácil de agregar a cualquier aplicación utilizando la herramienta adecuada.
Mejoraremos una aplicación JS de pila completa (backend de Node.JS + frontend de React) para autenticar usuarios con OAuth (inicio de sesión social) y contraseñas de un solo uso (correo electrónico), incluyendo:- Autenticación de usuario - Administrar interacciones de usuario, devolver JWT de sesión / actualización- Gestión y validación de sesiones - Almacenar la sesión para solicitudes de cliente posteriores, validar / actualizar sesiones
Al final del masterclass, también tocaremos otro enfoque para la autenticación de código utilizando Flujos Descope en el frontend (flujos de arrastrar y soltar), manteniendo solo la validación de sesión en el backend. Con esto, también mostraremos lo fácil que es habilitar la biometría y otros métodos de autenticación sin contraseña.
Tabla de contenidos- Una breve introducción a los conceptos básicos de autenticación- Codificación- Por qué importa la autenticación sin contraseña
Requisitos previos- IDE de tu elección- Node 18 o superior