GithubHelp home page GithubHelp logo

dghaehre / joy Goto Github PK

View Code? Open in Web Editor NEW

This project forked from joy-framework/joy

0.0 0.0 0.0 2.27 MB

A full stack web framework written in janet

Home Page: https://joy.swlkr.com

License: MIT License

Clojure 97.13% CSS 0.33% Dockerfile 0.90% Procfile 0.03% Janet 1.61%

joy's Introduction

You Found Joy!

Joy is a full stack web framework written in janet

(use joy)

(route :get "/" :home)
(defn home [request]
  (text/plain "You found joy!"))

(def app (app))

(server app 9001)

Getting Started

First make sure janet is installed

Next, install the joy cli like this

jpm install joy

Hopefully the joy executable will be on your path and ready to roll. If it isn't and you're like me and use homebrew, add this to your .zprofile:

export PATH=/usr/local/Cellar/janet/<your janet version here>/bin:$PATH

Then make sure you reload the profile:

source ~/.zprofile

Now, run the following from your terminal

joy new my-joy-project

This should create a new directory called my-joy-project and it should create a few files and things to get you started.

Taking it for a spin

Now that we have a project set up, it's time to test it out in the browser:

joy server

This should start an http server that's listening at http://localhost:9001.

Next, let's create a database, a table and connect it with routes and a few functions for handling requests.

Create a new sqlite database

If you aren't already in the my-joy-project directory, go ahead and get in there. Now run

joy create db

This creates a new empty database named dev.sqlite3.

The default template doesn't assume you want a database so you'll need to connect to it in main.janet:

; # main.janet

(defn main [& args]
  (db/connect (env :database-url))
  (server app (env :port))
  (db/disconnect))

Create a database table

Run this to create a new migration with a table with a few columns:

joy create table account 'email text unique not null' 'password text not null'

This has created one file in your db/migrations folder that is waiting to get applied to the database.

Run database migrations

Run this from your terminal

joy migrate

This will migrate your database and create a new file db/schema.sql

Generate helpful routes

In joy there are no ORMs, no classes, and no objects, just functions that take requests and return responses.

Let's generate a few routes for the table from earlier:

joy create controller account

Those commands have created another new file: routes/account.janet and updated your main.janet file with an import statement so the account routes get set up.

Go ahead and check out the new account routes in the browser now: http://localhost:9001/accounts

Joy can do a lot more than that, check out the docs here

Why?

I wanted something that felt like coast but took so little resources (memory + cpu) I could run dozens (if not hundreds) of websites on a cheap VPS.

Docker/Docker Compose

In order to make using joy more portable, we wanted to include a Dockerfile that creates an easy place for you to mount your code in and run joy without having to install anything or manage permissions on your local.

joy's People

Contributors

cpjolicoeur avatar goto-engineering avatar hammywhammy avatar harryvederci avatar hweeks avatar hxw avatar mikebeller avatar noocsharp avatar oz123 avatar pepe avatar swlkr avatar uvtc avatar yumaikas avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.