streamy 0.0.7

  • README.md
  • Installing
  • Versions
  • 0

Streamy for Dart (experimental)

Build Status

Streamy is a feature-rich RPC/API framework for applications written using Dart programming language. It relies on Google API Discovery file format for API description. Streamy also provides out-of-the-box JSON-over-REST protocol.

Using Streamy your application can:

  • Access many Google APIs, such as Google Calendar API
  • Talk to your own APIs built using Google Cloud Endpoints
  • Talk to your own APIs hosted on your own servers and described using Google Discovery format

Features

  • Rich Entity/Request/Resource objects: mutable, immutable, observable with Map-like interface
  • Fully customizable (in fact, fully replaceable) request handling pipeline
    • Caching
    • Request deduplication
    • API proxy
    • One-shot and keep-alive
    • Tracing
    • Out-of-the-box JSON-over-REST implementation
    • Transactional API
    • Request batching

5-Minute Tutorial

Let's write a command-line program that shortens URLs using Google URL Shortener API.

What you need for this tutorial

  • Dart SDK (add Dart's bin folder to your PATH)

Get Full Streamy

The simplest way is to use git:

> git clone https://github.com/google/streamy-dart.git streamy-dart
> cd streamy-dart

Can't I just get it from pub?

Yes, and no. You can and should use pub to import Streamy runtime library necessary to run your app. However, Streamy comes with command-line tools to work with Discovery files and generate API client libraries, so you need to download the full version.

Get a Discovery file

Find one for the API you want to access. Let's use Google URL shortener as example:

> curl https://www.googleapis.com/discovery/v1/apis/urlshortener/v1/rest >urlshortener.json

Generate client library

> dart bin/apigen.dart \
    --discovery_file=urlshortener.json \
    --client_file=urlshortener.dart \
    --library_name=urlshortener

What just happened?

The apigen.dart program provided by Streamy reads the discovery file (urlshortener.json in the example) and produces a Dart file (urlshortener.dart in the example) that contains an API client library for the API described in the discovery file. You can also give the library your own custom name (urlshortener in the example).

Use it

Let's create an entry point for our program, called main.dart, which contains the following code:

import 'urlshortener.dart';
import 'package:streamy/impl_server.dart';

main(List<String> args) {
  var requestHandler = new ServerRequestHandler();
  var api = new Urlshortener(requestHandler);
  api.url.insert(new Url()..longUrl = args[0])
    .send().listen((Url response) {
      print('Shortened to ${response.id}');
    });
}

We are done. Let's run the program:

> dart main.dart http://www.google.com

This should print something like:

Shortened to http://goo.gl/fbsS

What just happened?

import 'urlshortener.dart';

This line imports the API client library that we just generated from the discovery file.

import 'package:streamy/impl_server.dart';

This import provides an implementation of Streamy's RequestHandler interface. This particular implementation works for server-side and command-line apps. If your app runs in the web-browser, use package:streamy/impl_html.dart and HtmlRequestHandler instead.

main() {
  var requestHandler = new ServerRequestHandler();
  var api = new Urlshortener(requestHandler);

The above two lines instantiate a Urlshortener API client backed by ServerRequestHandler.

  api.url.insert(new Url()..longUrl = args[0])

This is an example of how you create an API request. Streamy API generator generates a fully type-annotated root API class (Urlshortener), resources (url), resource methods (insert), entity classes (Url) as well as getters/setters for properties on the entities (longUrl), so you can use auto-completion in your IDE and rely on compiler warnings to tell you about issues in your usage of the API.

    .send().listen((Url response) {
      print('Shortened to ${response.id}');
    });

Finally, we .send() the request to the server and .listen(...) to a Stream of responses.

}

1. Depend on it

Add this to your package's pubspec.yaml file:


dependencies:
  streamy: "^0.0.7"

2. Install it

You can install packages from the command line:

with pub:


$ pub get

Alternatively, your editor might support pub get. Check the docs for your editor to learn more.

3. Import it

Now in your Dart code, you can use:


import 'package:streamy/streamy.dart';
        
Version Uploaded Documentation Archive
0.0.7 Nov 19, 2013 Go to the documentation of streamy 0.0.7 Download streamy 0.0.7 archive
0.0.4 Jun 20, 2013 Go to the documentation of streamy 0.0.4 Download streamy 0.0.4 archive
0.0.2 Jun 18, 2013 Go to the documentation of streamy 0.0.2 Download streamy 0.0.2 archive
0.0.1 Jun 18, 2013 Go to the documentation of streamy 0.0.1 Download streamy 0.0.1 archive

Analysis

This feature is new.
We welcome feedback.

We analyzed this package, and provided a score, details, and suggestions below.

  • tool failures on Dec 6, 2017
  • Dart: 2.0.0-dev.8.0
  • pana: 0.7.3+1

Scores

Popularity:
Describes how popular the package is relative to other packages. [more]
0
Health:
Code health derived from static analysis. [more]
0
Maintenance:
Reflects how tidy and up-to-date the package is. [more]
0
Overall score:
Weighted score of the above. [more]
0

Platforms

Detected platforms:

Error(s) prevent platform classification.

Suggestions

  • Fix lib/generator/emitter.dart.

    Strong-mode analysis of lib/generator/emitter.dart failed with the following error:

    line: 108 col: 47
    The named parameter 'htmlEscapeValues' isn't defined.

  • Fix lib/indexed_cache.dart.

    Strong-mode analysis of lib/indexed_cache.dart failed with the following error:

    line: 55 col: 40
    2 required argument(s) expected, but 1 found.

  • Fix further 8 Dart files.

    Similar analysis of the following files failed:

    • lib/testing/testing.dart
    • lib/testing/dynamic_entity.dart
    • lib/runtime/request.dart
    • lib/runtime/multiplexer.dart
    • lib/runtime/global.dart
    • lib/runtime/entity/wrapper.dart
    • lib/runtime/entity/util.dart
    • lib/runtime/entity/raw.dart
  • Maintain CHANGELOG.md.

    Changelog entries help clients to follow the progress in your code.

Dependencies

Package Constraint Resolved Available
Direct dependencies
args >=0.8.7 1.2.0
browser any 0.10.0+2
fixnum >=0.8.7 0.10.6
json >=0.8.7 0.10.0
meta >=0.8.7 1.1.2
mustache >=0.1.5 1.0.0
observe >=0.8.7 0.13.1+3 0.15.1
quiver >=0.12.0 0.26.2
Transitive dependencies
analyzer 0.25.0+1 0.30.0+4
async 1.13.3 2.0.1
barback 0.15.2+13
charcode 1.1.1
cli_util 0.0.1+2 0.1.2+1
code_transformers 0.2.9+3 0.5.1+3
collection 1.14.3
logging 0.11.3+1
matcher 0.12.1+4
pool 1.3.3
smoke 0.3.5 0.3.6+3
source_maps 0.10.4
source_span 1.4.0
stack_trace 1.9.1
utf 0.9.0+3
watcher 0.9.7+4
when 0.2.0
which 0.1.3
Dev dependencies
benchmark_harness >=0.8.7
path any 1.5.1
unittest any