To have a look at what we are at:
Currently the scoring application can only be reliably used as a hosted service. To use:
- set up a server running nodejs nodejs.org
- download the source or clone the repository using git.
- Open a command prompt and navigate to the directory where you cloned the repository or extracted the downloaded zip-file.
- Execute the following command:
npm install
(this installs all dependencies. It's a neccesarry step for each install) - Run
node localserver.js
then open localhost:1390 in your browser- to specify another port, use
node localserver.js -p 8000
- to add basic authentication, use
node localserver.js -u username:password
- to specify another port, use
In the near future, we plan to have "ready to go" software available as:
- executable, for Windows, Mac OS and Linux
- app, for iOS, Android and windows
- a hosted service, as described above
To contribute to this repository, please make a fork, make your changes and submit a pull request.
This way of work allows us to maintain proper code quality, which is important when working with a large amount of people on the same project. Feel free to join the discussion on the issues page
Prerequisites
- nodejs nodejs.org. Make sure you have a recent version (>6) to get npm version >3.
- grunt (
npm install -g grunt-cli
)
- Clone the repository
npm install
This is mainly used for development.
node localserver.js
then open localhost:1390/nocache.html- to specify another port, use
node localserver.js -p 8000
- to add basic authentication, use
node localserver.js -u username:password
- to specify a data dir use
node localserver -d datadir
Relative paths are relative to the localserver script. Absolute paths are, well, absolute. Defaults todata
- to specify another port, use
- note that we load
nocache.html
to circumvent the offline cache mechanism
- run
karma start
- or run
grunt karma
- for a desktop build:
grunt nwjs
- for a mobile build:
grunt phonegap
- to build only one of iOS or Android, use
grunt phonegap:ios
orgrunt phonegap:android
respectively
For the phonegap build, copy pgbuildconfig.example.json
to pgbuildconfig.json
and adjust your phonegap build credentials. You can create an account on phonegap build. Also, make sure you you copy .cordova/config.example.json to .cordova/config.json and insert your application ID from phonegap build into it. The first time you build the app you must comment the app ID line out, it will generate one for you. Afterwards check the Phonegap build website for the generated app ID.
NOTE: remove the comments in the copied file, as it is not valid JSON as it is.
For iOS, see Building for iOS
- run
grunt challenge
This will rebuild html, pdf and js versions of the challenge. This can also be done individually if you'd wish:
- run
grunt html
- run
grunt pdf
- run
grunt js
These files are also included in the repo: challenges/html
, challenges/pdf
, challenges/js
- [original proposal](docs/proposal/Scoring System project proposal-v2.pdf)
- architecture documents
- templating
- interface
- internationalization
See case issues
Help is welcome. Please comment on the case if you plan to start working on one.
This projected is licensed under the terms of the GNU GPL v2.0 licenses
Basically, it allows users to legally copy, distribute and modify software. This means you can:
- Copy it onto your own servers, your client’s servers, your own computer, pretty much anywhere you want. There’s no limit to the number of copies you can make.
- Provide a download link on your website. Put the software on a bunch of thumb drives and give them away. Print out the source code and throw it from the rooftops (please don’t, though, because that would waste a lot of paper and make a mess). Charge a fee to distribute the software.
- If you want to charge someone to provide the software, set it up on their website or do anything else related to it, you can do so. But, you must give them a copy of the GNU GPL, which basically tells them that they could probably get the software elsewhere for free. Best to be up front about that, and about why you’re charging them.
- If you want to add or remove functionality, go ahead. If you want to use a portion of the code in another project, you can. The only catch is that the other project must also be released under the GPL. Ideally we would want you to share your improvements back with us on this GitHub.
- We welcome your feedback but please remember that this software comes with no guarantees. We are dedicated volunteer and experienced software developers and will do our best make sure we make a valuable and reliable contribution to the community. However the use of this software is at your own risk.