node_interop 0.1.0-beta.4 copy "node_interop: ^0.1.0-beta.4" to clipboard
node_interop: ^0.1.0-beta.4 copied to clipboard

outdatedDart 1 only

Interop library for writing NodeJS apps and modules in Dart.

NodeJS interop library Build Status Pub Gitter #

Write applications in Dart, run in NodeJS. This is an early preview, alpha open-source project.

What is this? #

node_interop provides JavaScript bindings and enables running Dart applications in NodeJS.

Some Node modules are also exposed as idiomatic Dart libraries. For instance, in addition to Node's http module bindings this package provides a HTTP client implementation based on Dart's http package.

Here is an example app using this client:

import 'package:node_interop/http.dart';

void main() async {
  var http = new NodeClient();
  var response = await http.get('https://example.com');
  print("Response code: ${response.statusCode}.");
  http.close(); // close any open IO connections.
}

There is not much Node or JS specific about this app, it looks very much like a regular Dart app. If you are familiar with Dart node_interop allows you to stay in comfortable environment of all the tools provided in Dart SDK and IDEs.

Examples #

Checkout example/ folder of this repository for some example apps using different APIs.

Status #

This is a early preview, alpha version which is far from being feature complete. Breaking changes are likely to occur.

Make sure to checkout CHANGELOG.md after every release, all notable changes and upgrade instructions will be described there.

If you found a bug, please don't hesitate to create an issue in the issue tracker.

Usage #

How to create a simple Node app written in Dart:

  1. Create a new Dart project. Stagehand is a great way to scaffold all the boilerplate:
$ pub global activate stagehand
$ mkdir my_node_app
$ cd my_node_app
$ stagehand package-simple # if you have .pub-cache in your PATH, or
$ pub global run stagehand package-simple # if you don't have it in your PATH
  1. Add dependency and transformers to the generated pubspec.yaml
dependencies:
  node_interop: '>=0.1.0 <0.2.0'

transformers:
  - $dart2js
  - node_interop # <- must go after dart2js!
  1. Create node/main.dart and write some code:
import 'package:node_interop/fs.dart';

void main() async {
  var fs = new NodeFileSystem(); // access Node `fs` module
  print(fs.currentDirectory); // prints the path from `process.cwd()`
  var files = await fs.currentDirectory.list().toList();
  print(files); // lists current directory contents
}
  1. Compile. Tell Pub to build node/ folder:
$ pub build node/
  1. Run the app. Compiled app is located in build/node/main.dart.js:
$ # assuming you have NodeJS installed:
$ node build/bin/main.dart.js
$ # If everything worked well you should see your current
$ # directory contents printed out.

Libraries #

node_interop consists of a set of libraries.

Node Interop #

import 'package:node_interop/node_interop.dart'.

Main library which provides NodeJS API bindings as-is. Not all of the APIs are implemented at this point, in fact, it's a small percentage. If you didn't find a class or method you were looking for, please create an issue or submit a pull request.

You have to explicitly require a Node module which declares an API you want to use. Refer to dartdoc for more details. Here is an example if using bindings directly:

import 'package:node_interop/node_interop.dart';

void main() {
  // Require specific modules:
  FS nodeFS = require('fs');
  OS nodeOS = require('os');
  // Using globals:
  console.log('message');
}

Note that bindings provide direct access to JavaScript objects and functions and you need to make sure objects are properly converted when passed between Dart and JS parts of the app (except primitives), as well as Dart functions are wrapped with allowInterop when passed to JS.

node object

Special node object provides convenience methods to access Node's runtime and platform information as well as some global functionality:

import 'package:node_interop/node_interop.dart';

void main() {
  // Get platform details like environment variables, OS or current script:
  Map<String, String> env = node.platform.environment;
  print(env);
  print(node.platform.script); // prints absolute path to the executed script.

  // Require Node module:
  FS fs = node.require('fs');

  // Export something:
  node.export('simplePi', 3.1415);
}

FS #

import 'package:node_interop/fs.dart'.

Exposes Node's file system API as a set of Dart classes compatible with "dart:io" (specifically it implements interfaces from the file package).

Note that not all methods are currently implemented for File and Directory classes.

HTTP #

import 'package:node_interop/http.dart'.

Implements Dart-style HTTP client using http package interface.

There are several benefits to use this client over plain JS bindings:

  • Encapsulates HTTP/HTTPS connections, no need to juggle with Node's "http" and "https" modules.
  • Replaces callbacks with Dart Futures which enables async/await.
  • Encapsulates JS interop logic like allowInterop.
  • Provides very Dart-like experience.

Future releases of this library will also provide implementation of ("dart:io" compatible) HttpServer powered by Node IO system.

Async #

Contains Dart wrappers around Node's built-in Readable and Writable streams. Following classes are provided:

  • ReadableStream<T> implements Stream<T>.
  • WritableStream<T> implements StreamSink<T>.
  • NodeIOSink extends WritableStream<List<int>> implements IOSink.

Most of the higher level abstractions in FS and HTTP libraries use these classes under the hood.

Features and bugs #

Please file feature requests and bugs at the issue tracker

49
likes
0
points
213k
downloads

Publisher

unverified uploader

Weekly Downloads

Interop library for writing NodeJS apps and modules in Dart.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

barback, file, glob, http, js, node_preamble, platform

More

Packages that depend on node_interop