Compare commits

..

No commits in common. "829bf8be4aadb9b8b227f45b60d61e76b66fe63a" and "24bf60f245ddf469af87e47cb06e2b8c1b3e2e8b" have entirely different histories.

14 changed files with 12 additions and 137 deletions

View File

@ -1,19 +1,10 @@
prod: # execute this target on the production server in the nix-shell prod: # execute this target on the production server in the nix-shell
rm -fr franklincce/staticfiles
cd franklincce; python3 manage.py collectstatic cd franklincce; python3 manage.py collectstatic
sh gen_kb.sh sed "s/change_me/$(shell shuf -i1-1000000 -n1)/g" .env.prod.orig > .env.prod
sed "s|change_me|$(shell dd if=/dev/urandom bs=1024 count=1|base64)|g" .env.prod.orig > .env.prod sed "s|change_me|$(shell dd if=/dev/urandom bs=1024 count=1|base64)|g" .env.prod.orig > .env.prod
docker-compose -f docker-compose.prod.yml up -d --build docker-compose -f docker-compose.prod.yml up -d --build
permissions: db.sqlite3 permissions:
chmod -f 660 db.sqlite3 chmod -f 660 db.sqlite3
echo "make sure that db.sqlite3 is owned by group users" echo "make sure that db.sqlite3 is owned by group users"
db.sqlite3:
touch db.sqlite3
make_kb:
sh gen_kb.sh
clean:
rm -fr franklincce/staticfiles
docker-compose -f docker-compose.prod.yml down -v

View File

@ -2,48 +2,7 @@ yig
=== ===
`yig` is a django app for exploring bills and resolutions in previous YMCA CCE conferences. `yig` is a django app for exploring bills and resolutions in previous YMCA CCE conferences.
It's sort of ballooned to also contain a knowledge-base thing.
## Deploying in production ## licensing
0. Ensure that you have Docker installed and good to go. see the `LICENSE.md` file
For NixOS machines, this involves the following:
```nix
{ ... }
{
virtualisation.docker.enable = true;
users.users.<your user>.extraGroups = [ ... ] ++ [ "docker" ];
}
```
1. Enter the `nix-shell`.
2. `make permissions`
3. `make`
To tear down the docker container, type `make clean`.
If you've just started the instance, you also need to configure a superuser.
1. Run `docker ps | grep yig-web | awk -F' ' '{print $1}'` to get the container id
2. Run `docker exec -it <container-id> bash` to get a shell.
3. Run `python3 manage.py createsuperuser` and follow the prompts.
## Usage
In order to use the `explorer` component of this package, you need to add some legislative texts.
These are in the form of PDFs -- they come from the YMCA CCE website or are sometimes emailed or otherwise shared with you.
Only these PDFs will work because they follow a very specific format which the software exploits.
1. Login with your admin account.
2. Click on the `add` button next to `Legislation books` in the sidebar
3. Upload your book, add a name, and choose the correct `Import strategy`
4. Click save
## More information
More information about operation of this project can be found in the [knowledgebase](./kb) directory.
## License
`yig` is licensed under the AGPLv3 -- the terms of the license are available in [`LICENSE.md`](./LICENSE.md).

View File

@ -24,4 +24,5 @@ services:
depends_on: depends_on:
- web - web
volumes: volumes:
static_volume: static_volume:
db_persist:

View File

@ -14,4 +14,5 @@ to_register = [
[models.LegislationClassification] [models.LegislationClassification]
] ]
for i in to_register: for i in to_register:
admin.site.register(*i) admin.site.register(*i)
print(i)

View File

@ -14,7 +14,6 @@
<nav id="navbar" class="boxed"> <nav id="navbar" class="boxed">
<div id="leftnav"> <div id="leftnav">
<a href="/explorer">explorer</a> <a href="/explorer">explorer</a>
<a href="/kb">knowledge</a>
</div> </div>
<div id="rightnav"> <div id="rightnav">
<a href="/explorer/all">all</a> <a href="/explorer/all">all</a>

View File

@ -11,7 +11,6 @@ https://docs.djangoproject.com/en/4.2/ref/settings/
""" """
import os import os
import random
from pathlib import Path from pathlib import Path
@ -19,9 +18,6 @@ from pathlib import Path
BASE_DIR = Path(__file__).resolve().parent.parent BASE_DIR = Path(__file__).resolve().parent.parent
SECRET_KEY = os.environ.get("SECRET_KEY") SECRET_KEY = os.environ.get("SECRET_KEY")
if not SECRET_KEY:
print("[!!!] YOU'RE USING A RANDOM SECRET_KEY -- CHANGE THIS IF YOU'RE GOING INTO PROD")
SECRET_KEY = random.randint(1, 100000000000000)
DEBUG = bool(os.environ.get("DEBUG", default=0)) DEBUG = bool(os.environ.get("DEBUG", default=0))

View File

@ -1,10 +0,0 @@
files=$(find kb -type f | awk -F'/' '{print $NF}')
IFS='
'
mkdir -p franklincce/staticfiles/kb
for file in $files; do
without_extension=${file%.*}
echo $file, $without_extension
pandoc -s --template=./template.html -f markdown -t html -o "franklincce/staticfiles/kb/$without_extension.html" "kb/$without_extension.md" --lua-filter=links-to-html.lua
done

View File

@ -1,16 +1 @@
--- # todo
title: "Contributing to the knowledgebase"
---
1. If you haven't a GitHub account, [create one](https://github.com/signup) and sign in.
2. Navigate to the `yig` repository in the VSCode Web Editor, or click [here](https://github.dev/stupidcomputer/yig)
3. Click on the `kb/` directory on the sidebar.
4. Select an article that you'd like to change.
5. Make your changes.
6. Click on the 'source control' tab on the left (the one that looks like a tree)
7. Click the "plus" icon on all the entries in the left panel, and write a message explaining your changes, and then click "Commit and Push"
8. You'll get a prompt to create your own "fork"; say yes.
9. Navigate back to [Github](https://github.com) and click on the "yig" link in the upper left area.
10. Click the "Compare and pull request" button, then scroll down and click "create pull request".
Thanks for your contribution!

View File

@ -1,7 +0,0 @@
---
title: "Franklin CCE Knowledgebase"
---
## Model UN
- [Writing a resolution](./writing-resolution.md)

View File

@ -1,5 +0,0 @@
---
title: "Writing a Resolution"
---
This is a test

View File

@ -1,4 +0,0 @@
function Link(el)
el.target = string.gsub(el.target, "%.md", ".html")
return el
end

View File

@ -16,8 +16,4 @@ server {
location /static/ { location /static/ {
alias /home/app/web/staticfiles/; alias /home/app/web/staticfiles/;
} }
location /kb {
alias /home/app/web/staticfiles/kb;
}
} }

View File

@ -1,4 +1,4 @@
{ pkgs ? import <nixpkgs> {} }: { pkgs ? import <nixpkgs> {} }:
pkgs.mkShell { pkgs.mkShell {
nativeBuildInputs = with pkgs.python311Packages; [ django pymupdf ] ++ [ pkgs.docker-compose pkgs.gnumake pkgs.pandoc ] ; nativeBuildInputs = with pkgs.python311Packages; [ django pymupdf ] ++ [pkgs.docker-compose pkgs.gnumake] ;
} }

View File

@ -1,27 +0,0 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="generator" content="pandoc" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
<title>$title$</title>
<link rel="stylesheet" href="/static/style.css">
<link rel="stylesheet" href="/static/tn.css">
</head>
<body>
<nav id="navbar" class="boxed">
<div id="leftnav">
<a href="/explorer">explorer</a>
<a href="/kb">knowledge</a>
</div>
</nav>
<div class="boxed">
<h1>$title$</h1>
$body$
</div>
</body>
</html>