Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mmaelicke/pyedu
Learning Python interface
https://github.com/mmaelicke/pyedu
Last synced: about 2 months ago
JSON representation
Learning Python interface
- Host: GitHub
- URL: https://github.com/mmaelicke/pyedu
- Owner: mmaelicke
- License: mit
- Created: 2017-06-05T09:34:53.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-09-05T12:01:13.000Z (over 7 years ago)
- Last Synced: 2024-10-15T18:50:55.493Z (3 months ago)
- Language: Python
- Size: 185 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
PyEDU
=====The Python Educational Suite (PyEDU) is a flask application for guided Python exercise creation and completion. It
was created for the Python I and Python II lectures at the Chair for remote sensing and landscape information systems
at the Univeristy of Freiburg, but will however work with other exercises as well.The application is meant to be run from the localhost so that the exercise code is run in a local Python environement.
Before running it on a remote server, one has to make sure that no harmful code is included in the exercises before
running the code. However, the local application can connect to a local or remote database. For Python I and II these
remote connections are already included in an encrypted file. As the user has the decryption key, the connection can
be used. In the supplementary folder is Jupyter notebook which can create such a file for other remote locations.Installation
~~~~~~~~~~~~Although the project will be on PyPI, the installation using git favored. One of the next updates will included
a version check and auto-update function, which will be based on git and might not work when PyEDU is installed
using pip. It can be installed using:.. code-block:: bash
git clone https://github.com/mmaelicke/pyedu.git
cd pyedu
pip install -r requirements.txt
python setup.py installUsing remote connections
~~~~~~~~~~~~~~~~~~~~~~~~In order to use a remote connection you'll need a file with the decryption key in it. The connection and keys are in the
pyedu/enc folder. To use a remote connection as default, rename the .enc file you wish to use to 'remote.enc' and
place the key as 'remote.key' into the enc folder. Then the default flask settings will use this connection as
the default connection.
For one of the next updates, there will be the possibility to enter the cleartext key during the start process. Then
the user cannot manually decrypt the enc file anymore.Starting the application
~~~~~~~~~~~~~~~~~~~~~~~~In order to start the application, in the pyedu/pyedu folder use:
.. code-block:: bash
python manage.py runserver
If you like to use another flask configuration, like with enabled debug mode or a local connection, you can use the -c
(--config) flag:.. code-block:: bash
python manage.py -c local_dev runserver
Once the server is running, the application can be accessed with your browser and activated Javascript at:
.. code-block::
http://locahost:5000
With one of the next versions, the application will be able to create a shortcut on Windows or a executable symlink on
Linux for starting the application.Security
~~~~~~~~Please note, that this application is not made for remote usage and still under active development. If you decide to
run this application with a remote database, please note that it is possbile to read the database connection and
connect externally. To come around external assingment injection, the application will include a different assign
route with a future release, that will shift the solution check to a remote REST API and therefore make the student
db user a read only db user.