class Analyzer::Dart::Angel3

Overview

Angel3 (package:angel3_framework/angel3_framework.dart) is a full-featured, Express-style Dart server framework. Routes are registered against an Angel() instance with a method per verb:

var app = Angel(); app.get('/users', (req, res) => _listUsers(req)); app.post('/users', createUser); app.all('/health', (req, res) => 'ok');

Routes can be grouped under a shared prefix with group, whose second argument is a closure receiving a child router:

app.chain([cors()]).group('/api', (router) { router.get('/version', (req, res) => 'v0'); // GET /api/version });

group blocks nest, composing their prefixes. Path captures use the Express-style :id syntax, surfaced as {id} path params.

Routes are bound to variables holding an Angel() instance (or an Angel-typed parameter) and to the child-router parameter of a group closure, so calls on unrelated receivers (e.g. the package:http client's http.get(url)) are never mistaken for routes.

Not yet handled: reflection-based @Expose controller classes and the chain([...]).<verb>(...) form where the verb is called directly on a chain(...) result rather than a bound router variable.

Defined in:

analyzer/analyzers/dart/angel3.cr

Constant Summary

ALL_VERBS = ["GET", "POST", "PUT", "PATCH", "DELETE", "HEAD", "OPTIONS"]
ANGEL_ASSIGN_REGEX = /(?:^|[;{}=(,\s])(?:final|var|const|late)\s+(?:Angel\s+)?([A-Za-z_]\w*)\s*=\s*(?:await\s+)?Angel\s*\(/

Variables holding an Angel() instance, plus parameters/fields typed Angel (so Future configureServer(Angel app) is picked up too).

ANGEL_TYPED_REGEX = /(?:^|[;{}(,])\s*Angel\s+([A-Za-z_]\w*)/
CALL_REGEX = /(?<![\w$.])([A-Za-z_]\w*)\s*\.\s*([a-zA-Z]+)\s*\(/

Receiver .verb( calls; (?<![\w$.]) keeps the receiver to a single identifier so chain([...]).post( (receiver is a )) is skipped.

GROUP_REGEX = /\.group\s*\(/
HANDLER_REFERENCE_REGEX = /\A[A-Za-z_]\w*(?:\.[A-Za-z_]\w*)*\z/
HTTP_METHOD_MAP = {"get" => "GET", "post" => "POST", "put" => "PUT", "patch" => "PATCH", "delete" => "DELETE", "head" => "HEAD", "options" => "OPTIONS"}

Instance Method Summary

Instance methods inherited from class Analyzer

analyze analyze, base_path : String base_path, base_paths : Array(String) base_paths, callees_needed? : Bool callees_needed?, logger : NoirLogger logger, parallel_analyze(files : Array(String), &block : String -> Nil) parallel_analyze, read_file_content(path : String) : String read_file_content, result : Array(Endpoint) result, url : String url

Constructor methods inherited from class Analyzer

new(options : Hash(String, YAML::Any)) new

Macros inherited from class Analyzer

define_getter_methods(names) define_getter_methods

Instance methods inherited from module FileHelper

all_files : Array(String) all_files, get_files_by_extension(extension : String) : Array(String) get_files_by_extension, get_files_by_prefix(prefix : String) : Array(String) get_files_by_prefix, get_files_by_prefix_and_extension(prefix : String, extension : String) : Array(String) get_files_by_prefix_and_extension, get_public_dir_files(base_path : String, folder : String) : Array(String) get_public_dir_files, get_public_files(base_path : String, anchors : Array(String) = ["shard.yml", "Gemfile"]) : Array(String) get_public_files

Instance Method Detail

def analyze #

[View source]