an oversimplified application to register attendees at a conference or event

Davide Alberani 05ef1a3843 use Alpine Linux to reduce image size 4 years ago
build 4269b22a60 #34: inject jQuery also on production 7 years ago
config eda55092d3 fixes #33: webpack 2 - the future is here 7 years ago
docker-tools 031b0b9233 fix #41: Docker support 6 years ago
docs 031b0b9233 fix #41: Docker support 6 years ago
src a28c08f2b5 improve margin for notes 6 years ago
ssl 1e765a04c9 ssl directory 7 years ago
static f1c19299c4 add favicon 6 years ago
tests 95ace7f8a4 fixes #13: permissions to modify unregistered attendees and notes 7 years ago
.babelrc c2fe85f771 update babel 7 years ago
.dockerignore 031b0b9233 fix #41: Docker support 6 years ago
.gitignore 031b0b9233 fix #41: Docker support 6 years ago
Dockerfile 05ef1a3843 use Alpine Linux to reduce image size 4 years ago
LICENSE.txt 890dad90db add license 7 years ago
README.md 2a89674275 fix WS-2019-0058 5 years ago
docker-compose.yml 031b0b9233 fix #41: Docker support 6 years ago
ibt2.py 2a89674275 fix WS-2019-0058 5 years ago
index.html f1c19299c4 add favicon 6 years ago
monco.py 031b0b9233 fix #41: Docker support 6 years ago
package.json 2a89674275 fix WS-2019-0058 5 years ago
utils.py bb411616b0 update doc 7 years ago

README.md

ibt2 - I'll be there, 2

I'll be there, 2 is an oversimplified application to register attendees at a conference or event.

Basic workflow:

  • if you want (not mandatory), login with your user; to create a new user, simply choose a username and a password. Benefit of logging in: only you or admins can edit/delete your entries.
  • pick a date
  • choose the group you want to join or the name of a new group
  • write your name and, optionally, a note
  • rinse and repeat

It's recommended to login with username admin and password ibt2, go to your personal page and change the password, if you've just installed ibt2. The admin user can change some global settings and also grant super cow powers to any other user.

For the notes, you can use the Markdown syntax.

Install, run, develop and debug

Docker

Just run:

docker-compose up

Old-fashioned installation

To install it:

wget https://bootstrap.pypa.io/get-pip.py
sudo python3 get-pip.py
# if you want to install these modules for an unprivileged user, add --user and remove "sudo";
# if you want to upgrade the versions already present in the system, also add --upgrade
sudo pip3 install tornado
sudo pip3 install pymongo
git clone https://github.com/raspibo/ibt2
cd ibt2

Installation of Node.js and npm is left as an exercise to the reader.

To run it:

# install dependencies (one time only, or every time the dependencies in package.json change)
npm install

# build for production with minification (each time the sources changes)
npm run build

# run the Python webserver at localhost:3000
npm run server

Now you can point your browser to http://localhost:3000/ (that's the server for production)

If you want, you can share a link to a specific day, specifying it in the yyyy-mm-dd format, like: http://localhost:3000/#/day/2017-01-20

You can also run the server in https, putting in the ssl directory two files named ibt2_key.pem and ibt2_cert.pem

Run a development environment

# install dependencies (one time only)
npm install

# run the Python web server using a testing database
npm run devserver &

# serve with hot reload at localhost:8080
npm run dev

# only when the devserver is running, you can also run the testsuite
python3 ./tests/ibt2_tests.py

Your browser will automatically open http://localhost:8080/ (that's the server for development)

Development

See the docs/DEVELOPMENT.md file for more information about how to contribute.

Technological stack

The web part is incuded; you need to install Node.js, Tornado, MongoDB and the pymongo module on your system (no configuration needed).

Other projects

Need something more sophisticated, that allows you to manage tickets to an event? Try EventMan(ager)

License and copyright

Copyright 2016-2019 Davide Alberani da@erlug.linux.it, RaspiBO info@raspibo.org

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.