Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xh4/web-toolkit
Lisp Web Toolkit
https://github.com/xh4/web-toolkit
client css dom html http javascript json lisp parser serializer server uri web websocket
Last synced: 3 months ago
JSON representation
Lisp Web Toolkit
- Host: GitHub
- URL: https://github.com/xh4/web-toolkit
- Owner: xh4
- License: bsd-3-clause
- Created: 2019-05-22T00:17:32.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-07-28T14:32:49.000Z (6 months ago)
- Last Synced: 2024-08-01T03:41:27.163Z (6 months ago)
- Topics: client, css, dom, html, http, javascript, json, lisp, parser, serializer, server, uri, web, websocket
- Language: Common Lisp
- Homepage: https://lisp-web-toolkit.com
- Size: 9.84 MB
- Stars: 73
- Watchers: 9
- Forks: 2
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Lisp Web Toolkit
Object-Oriented Reactive Lisp Systems for Rapid Web Application Development### Status
**Layer 1**: (*Work in Progress*) Rich set of features for fundamental Web-related technologies
HTTP, WebSocket, URI, JSON, DOM, HTML, CSS, JavaScript
**Layer 2**: (*Experimeltal*) Component abstraction and reactive behavior
Component, Live
**Layer 3**: (*Planning*) Integration with enterprise-class vendor libraries
[Ant Design](https://ant.design/), [Ant Vision](https://antv.vision/en), ...
### Systems
#### [HTTP](https://lisp-web-toolkit.com/#http)
WT.HTTP provides HTTP functionality based on [RFC 7231 Hypertext Transfer Protocol (HTTP/1.1)](https://www.ietf.org/rfc/rfc7231.txt), together with implementation of server and client.#### [WebSocket](https://lisp-web-toolkit.com/#websocket)
WT.WEBSOCKET provides WebSocket functionality based on [RFC 6455 The WebSocket Protocol](https://tools.ietf.org/html/rfc6455), with interface inspired by [JSR 356, Java API for WebSocket](https://www.oracle.com/technetwork/articles/java/jsr356-1937161.html). The system is tested against the [Autobahn WebSocket Testsuite](https://github.com/crossbario/autobahn-testsuite).#### [HTML](https://lisp-web-toolkit.com/#html)
WT.HTML implements HTML constructor, parser and serializer. The parser is designed to conform to the [WHATWG HTML Specification](https://html.spec.whatwg.org/multipage/), as is implemented by all major web browsers. It uses the Document Object Model (DOM) provided by WT.DOM.#### [JSON](https://lisp-web-toolkit.com/#json)
WT.JSON implements JSON encoder and decoder based on [ECMA-404 The JSON Data Interchange Standard](https://www.json.org/json-en.html). It distinguishes `null`, `false` and `[]` from Lisp's `NIL` thus supports identical transformation between JSON values. It provides object constructor and accessor to build and access nesting JSON objects. The system is tested against [JSONTestSuite](https://github.com/nst/JSONTestSuite).#### [URI](https://lisp-web-toolkit.com/#uri)
WT.URI provides URI parser, render and constructor with support for UTF-8 characters, IPv6 addresses and query parameters handling. It utilizes recursive descent [parser combinators](https://www.cs.nott.ac.uk/~pszgmh/monparsing.pdf) to provide a concise implementation that is close to the definition in [RFC 3986 Uniform Resource Identifier (URI): Generic Syntax](https://tools.ietf.org/html/rfc3986).#### [CSS](https://lisp-web-toolkit.com/#css)
WT.CSS implements CSS constructor, parser and serializer based on specifications introduced in [CSS Snapshot 2018](https://www.w3.org/TR/css-2018/#css).#### [JavaScript](https://lisp-web-toolkit.com/#javascript)
WT.JAVASCRIPT implements JavaScript parser and serializer based on [ECMAScript 2016 Language Specification](https://www.ecma-international.org/ecma-262/7.0/) (ECMA-262 7th Edition) with support for [JSX](https://reactjs.org/docs/introducing-jsx.html) syntax extension. It utilizes syntax tree components from the [ESTree](https://github.com/estree/estree) project.#### [DOM](https://lisp-web-toolkit.com/#dom)
WT.DOM implements Document Object Model (DOM) based on recent version of [DOM Living Standard](https://dom.spec.whatwg.org/), it covers chapters on [Nodes](https://dom.spec.whatwg.org/#nodes) and [Traversal](https://dom.spec.whatwg.org/#traversal).#### [Component](https://lisp-web-toolkit.com/#component)
WT.COMPONENT provices component abstraction, it combines [Web Components](https://developer.mozilla.org/en-US/docs/Web/Web_Components) style strong encapsulation and [React](https://reactjs.org/) style declarative DOM synchronization.### Roadmap
* Overall
* Use in production environments
* Write [documentation](https://lisp-web-toolkit.com)
* Carefully design conditions and errors
* Write more tests
* Add project build status graph
* Add code coverage informataion
* HTTP
* Use [Asynchronous I/O](http://www.lispworks.com/documentation/lw71/LW/html/lw-192.htm) in LispWorks
* Use [Recursive Event Dispatching (SERVE-EVENT)](https://github.com/sbcl/sbcl/blob/master/src/code/serve-event.lisp) in SBCL
* Abandon usocket & bordeaux-threads, write implementation-dependent code
* Implement server statistics and metrics monitoring
* Implement traffic throttling and message size limiting
* Implement authentication, authorization and access control
* Implement static file serving
* Implement cache control
* Implement compression
* Implement logging
* Implement [HTTP/2](https://tools.ietf.org/html/rfc7540)
* Implement common handlers
* Implement virtual host
* (Client) Support HTTPS
* (Client) Support compression and decompression
* (Client) Support HTTP Proxy
* (Client) Support SOCKS Proxy
* (Client) Support Basic Auth
* (Client) Implement Cookie store
* (Client) Support caching
* WebSocket
* Use [Asynchronous I/O](http://www.lispworks.com/documentation/lw71/LW/html/lw-192.htm) in LispWorks
* Use [Recursive Event Dispatching (SERVE-EVENT)](https://github.com/sbcl/sbcl/blob/master/src/code/serve-event.lisp) in SBCL
* Implement server statistics and metrics monitoring
* Implement traffic throttling and message size limiting
* Support [Compression Extensions](https://tools.ietf.org/html/rfc7692)
* Support WSS for both client and server
* URI
* Test against [Web Platform Tests](https://github.com/web-platform-tests/wpt)
* HTML
* Implement parser
* Implement pretty print(?) (NO)
* Refine element constractor error report
* Implement DOM, abandon CXML's DOM implementation
* Test against [Web Platform Tests](https://github.com/web-platform-tests/wpt)
* JSON
* Test against [JSONTestSuite](https://github.com/nst/JSONTestSuite)
* Implement accessors for object
* Implement identical transformation for JSON values (null, false, [])
* DOM
* Implement common used functions
* Implement namespace
* Implement XPath
* JavaScript
* Implement JavaScript <=> S-expression code transformer
* CSS
* Parse common used property values and implement CSSOM### Author
[Xiangyu He](https://xh.coobii.com) <[[email protected]](mailto:[email protected])>### License
Copyright 2018-2020 Xiangyu He. Released under the 3-Clause BSD License.