cl-deck-builder2/README.md
2024-01-21 02:35:35 -05:00

6.0 KiB

cl-deck-builder2

About

This is a project to...

  • Build TCG decks: "The Deck Builder"
  • Keep track of TCG inventory: "The Inventory Manager"
  • Support sale of TCG Inventory via "The Deck Builder"

It's a Caveman2 web app, written in Common Lisp.

The entire application may be built and run inside a Docker container.

You may access a live instance at https://phntsm.ddns.net/.

Usage

There are three components to this project. "The Inventory Manager", "The Deck Builder," and "The User Interface". The Deck Builder sources in-stock products from the Inventory Manager. When the Deck Builder constructs a Deck, it keeps a record of which cards are located in which decks. When a Deck is purchased, this information can be updated via a web interface. The User Interface is a convenient front-end.

The project may be used by loading a Docker image, loading the code directly into a Lisp sytem like SBCL, or using a development environment like Portacle.

Once loaded, follow the code below to start the development environment, or, if you're using the Docker image, simply type:

% make docker-build
% make docker-run

Installation

First, set up SBCL and Quicklisp.

If you're using Portacle, you should be all set already, just clone the repository.

Clone the master repository from http://phntsm.ddns.net/git/cl-deck-builder.git/:

% cd ~/quicklisp/local-projects/
git clone http://phntsm.ddns.net/git/cl-deck-builder.git/
;; You may have to push whatever directory you're in to *LOCAL-PROJECT-DIRECTORIES*
(push #P"~/code/cl-deck-builder2/" ql:*local-project-directories*)

;; Load cl-deck-builder2 and tests
(ql:quickload '(:cl-deck-builder2 :cl-deck-builder2-test))

;; cl-deck-builder2.asd finds src/package.lisp which contains package
;; definition - switch to this package for development.
(in-package :cl-deck-builder2)

;; Start the server:
;; in src/main.lisp we define a custom function, MY/START, that will
;; INVOKE-RESTART if the server is already running.
;;
;; IPv4
(my/start :address "0.0.0.0" :port 5001 :server :woo)
;; IPv6
(my/start :address "::" :port 5001 :server :woo)

;; For development session:
(use-package '(:cl-deck-builder2.db
               :cl-deck-builder2.draw
               :cl-deck-builder2.models
               :cl-deck-builder2.toolkit
               :cl-deck-builder2-test))

Requirements

You'll need Quicklisp, and the dependencies listed in the ASDF System Definition file, as well as the following system libraries installed.

  # Install Software
  % apt install build-essential git jq sbcl
  % apt install nginx fcgiwrap libev-dev sqlite3 libsqlite3-dev collectd imagemagick ruby ruby-sidekiq

  # For source code hosting
  % apt install cgit python3-pygments python3-markdown
  • What is build-essential Ubuntu, how to install and use it?
  • git: Version Control
  • jq: Parsin JSON files on the command line
  • SBCL: Lisp Implementation
  • NGINX: Web Server for HTTP, HTTPS, IPv4, IPv6, other services can be forwarded behind NGINX as well
  • fcgiwrap: Simple FastCGI wrapper for CGI scripts (The project runs as a CGI script)
  • libev: Event loop used by woo
  • sqlite3: In-memory database store
  • collectd: collectd is a daemon which collects system and application performance metrics periodically and provides mechanisms to store the values in a variety of ways, for example in RRD files. This also nets us RRDtool which we can use for charts and graphs.
  • ImageMagick: We use this to generate deck images and other various image manipulations.
  • Ruby: We use the Sidekiq job scheduler, which is written in Ruby.

You may want to set up cgit git web.

There is also a Dockerfile with a Makefile.

Author

Bubblegumdrop staticsunn@gmail.com

Copyright (c) 2024 Bubblegumdrop

License

GPLv3+

Localization Workflow

lisp.pot contains the string to translate that were extracted from the .lisp files.

djula.pot contains the strings to transtlate that were extracted from the djula templates.

gettext is the default translation engine.

Update Translations

To build the translations:

# Extract all {_ ... _} sequences from Djula templates
make locale/templates/LC_MESSAGES/djula.pot

# Extract all (_ ... _) sequences from LISP code
make locale/templates/LC_MESSAGES/lisp.pot

# Produce combined project template for translation
make locale/templates/LC_MESSAGES/cl-deck-builder2.pot

... make your translation edits to cl-deck-builder2.pot ...

Compile Translations

To Produce the .mo files, add your language to LOCALES in the Makefile then update the translations with the tr target:

LOCALES := en_US ja_JP

# Produce the translations
make tr

The default LANG is currently en_US in view.lisp:

(defun render (template-path &optional env (lang "en_US"))
"Use Djula to render a template."
(let ((template (gethash template-path *template-registry*)))
    (unless template
    (setf template (djula:compile-template* (princ-to-string template-path)))
    (setf (gethash template-path *template-registry*) template))
    (with-locale (lang)
    (apply #'djula:render-template*
            template nil
            env))))

TODO

See todo.md