data:image/s3,"s3://crabby-images/2d6be/2d6beb94e3b80f328993ad9e847f198cd5ce05d2" alt="JeffreyWang-U04J5APLPJ9"
data:image/s3,"s3://crabby-images/5751a/5751a511472dc46a697d7f68f803b51d9e684033" alt="goose-honk-on-fire emoji"
Posts tagged with :goose-honk-on-fire:
data:image/s3,"s3://crabby-images/2d6be/2d6beb94e3b80f328993ad9e847f198cd5ce05d2" alt="JeffreyWang-U04J5APLPJ9"
data:image/s3,"s3://crabby-images/2ed51/2ed510ea75ba19c6cdaeca4baa7e6fff4b80f630" alt="Tom"
data:image/s3,"s3://crabby-images/2ed13/2ed133a75d1ae83ec87c7a894caa8f22e49e128c" alt="cwi"
data:image/s3,"s3://crabby-images/51bf3/51bf36cb4c484961ee3e038142f8b2189eca0335" alt="ArcadeWise"
data:image/s3,"s3://crabby-images/35ffa/35ffab45611ed340c8486f8720069964d84d3aa6" alt="tetraoxygen"
data:image/s3,"s3://crabby-images/fbcff/fbcffc8b58d5bc6330e8493c10ecfbfc34bde6a6" alt="rishi"
define middleware { test, logger } from "./api" define guards { authed } from "./api" define handlers { getAllTodos, postTodos } from "./api" global | middleware logger fragment getTodosFragment(level) | guard authed(level) | middleware test route "/todos" { | middleware test get { | expand getTodosFragment("user") getAll } post { | expand getTodosFragment("admin") postTodos } } 🛠️ The Idyllic language reverses the conventional paradigm that surrounds Node REST APIs: usually, you have to write your functions _for a framework_. With Idyllic, you can assemble your API completely independently of your functions themselves—now, an API is simply a wrapper over regular old Typescript functions! The language itself comes with a pretty big suite of features (you can read more about them at the Github page): • Static typing with Typescript & definition types • Parameterized, first-class macro support with Fragments • Data pipelines with Sequences • First-class support for Middleware and Guards • Query parameter capturing • Request type definitions 🕸️ The repository also comes with a minimal HTTP server that takes in a compiled Idyll and starts up a fully-functioning API from it: import { IdyllicCompiler } from "@idyllic/compiler"; import { IdyllicServer } from "@idyllic/server"; (async () => { // The fromFile static method reads the file into a string for us const compiler = await IdyllicCompiler.fromFile("ast.idl") // The compile method executes all 5 stages of compilation automatically. const compiled = await compiler.compile() // The server constructor takes in a compiled Idyllic object. const server = new IdyllicServer(compiled) // The start function takes in a port number (defaults to 3000) and a function to be executed on start. server.start(3000, () => { console.log("Idyllic server has started!") }) })()💨 This server implementation’s pretty fast, too: in most cases, it comes close to (and in some cases, beats) Express! It’s derived directly from node’s built-in
http
module.
Idyllic’s been a project that I’ve dreamt of making for quite a while now, and I’m super happy with how it turned out! I’ve included a little walkthrough of an Idyllic project down below :) I can’t wait to see what you’ll build with it!
Special thanks to @JackyZhao @matthewgleich @safin.singh for being awesome along the way ✨data:image/s3,"s3://crabby-images/49466/49466de8431792932186302f184fb174c0ab5828" alt="anthonykung"
data:image/s3,"s3://crabby-images/05b72/05b7265c8972f58f54546b22c290297bb393101b" alt="thestarmansart"