Skip to content

Latest commit

 

History

History
105 lines (83 loc) · 4.69 KB

README.md

File metadata and controls

105 lines (83 loc) · 4.69 KB

prophecy

Shape your future, leave uncertainty behind

import { Future } from "@prophecy/future";
import { match } from "@prophecy/future/match";
import { writeToFile } from "@prophecy/node/filesystem";
import { abortAt, createAbortController, sendAbortableRequest } from "@prophecy/http";
import { Users, toJson, toStringifiedJson, toUsers } from "./schemas/users";

createAbortController()
  .and(abortAt({ seconds: 5 }))
  .and(sendAbortableRequest({ url: "https://jsonplaceholder.typicode.com/users" }))
  .and(toJson)
  .and(toUsers)
  .recover({ issue: "UserValidationIssue", remediation: () => Future.from<Users>((onValue) => onValue([])) })
  .and(toStringifiedJson({ pretty: true }))
  .and(writeToFile({ path: "users.json" }))
  .on({
    issue: match({
      UnexpectedIssue: () => console.error("Failed to instantiate an abort controller"),
      BadResponseIssue: () => console.error("Bad response from the server."),
      RequestCanceledIssue: () => console.error("Request canceled, nothing to do."),
      JsonParseIssue: () => console.error("Failed to parse the users from the response."),
    })
  });

Why

Objects are single values, they don't scale well.

Arrays are multiple values, they scale well, but are limited in time since they can't be asynchronous.

Promises are asynchronous, but they only emit one time, making them short lived.

Generators can emit multiple times, but lack a way of declaring explicitely their errors, plus errors can be thrown at you, even if they are not well documented.

Hence why this library has been created: provide a data structure that would allow to handle values that can span over time, with a strong emphasis on declaring what the possible errors could be, in order to be able to exhaustively handle them all.

Target

This library is aimed at anyone having some understanding of the main principles of functional programming since it has been designed with functional programming in mind.

And above all, this library is aimed at anyone wanting some sleep in the night, knowing they have successfully transpiled their code without errors, and so without any case left out since this library has a strong policy over errors and how to handle them all.

This library is not for those wanting a fast alternative to RxJS of Effect, nor those who don't value the importance of error handling in their code, those that might rather code only on the happy path, and not see the dark path, or those that would rather prefer using imperative programming instead.

Examples

Web

See example/web

Node

See example/node

Packages

Package Description
@prophecy/array Type-safe array manipulation
@prophecy/future Type-safe data structure for asynchronous inifinite data
@prophecy/http Type-safe http requests
@prophecy/node Type-safe Node.js APIs
@prophecy/state State management solution
@prophecy/string Type-safe string manipulation
@prophecy/syslog Type-safe Syslog implementation
@prophecy/time Type-safe time manipulation
@prophecy/web Type-safe Web APIs

What's left to do?

  • Use function overloading for package that deal with scalar types (string, array, number, ...)
  • Delete the state package in favor of useFuture
  • Remove the state library
  • Document the API for future (when, effect, useFuture)
  • Add more packages and packages functions
  • Document the whole API once it gets out of the real-world testing phase
  • Compare this library with RxJS and credit them
  • Compare this library with Effect and credit them
  • Find a cool logo
  • Add some unit testing and try to reach 100% code coverage
  • Create a documentation website
  • Publish all packages
  • Add a lot of documentation & comments in the source code (like a sea of comment, mediterranean sea level)
  • Handle server errors and emit them for @prophecy/node/http
  • Add support for the Bluetooth Web API
  • Add support for the USB Web API
  • Add support for the Battery Web API
  • Add support for the Background Sync Web API
  • Add support for the Beacon Web API
  • Add support for the Resize Observer Web API
  • Add support for the Intersection Observer Web API
  • Add support for the Mutation Observer Web API
  • Add support for the Proximity Sensor Web API
  • Add support for the Ambiant Light Sensor Web API
  • Add support for the Magnetometer Web API
  • Add support for the Gyroscope/Accelerometer Web API
  • Add support for the Screen Orientation Web API
  • Add support for the NFC Web API
  • Add support for the Operating System Node.js API
  • Add support for the DNS Node.js API