This is the client application for connecting to cptserver. CPT stands for Course Participation Tracker.
Should mostly work out of the box, if a cptserver is running.
- Install Android SDK
- Enable Dart Plugin
- Enable Flutter Plugin
- Install Flutter SDK
- Adapt the server details in
cptclient.yaml
. A template can be found incptclient-template.yaml
. - Choose Chrome (web) as build target and press the Run button. Alternatively you can use the command line:
flutter build web
As long as there is a temporary super-user ('admin' by default) configured in the server configuration file (cptserver.toml), you can login as this user with any password (the mask require >=1 password length) with full permissions.
After login, you should perform those steps:
- Change your first name and last name placeholders in the user administration.
- Change your password in the user administration. This will also generate new salt/pepper hashes.
- Create a new team in the team administration (e.g. "Admin" team).
- Give the admin team all permissions.
- Add yourself to the admin team.
- Remove the super-user from the server configuration file.
- Restart the server.
Current supported locales are EN and DE in main.dart
.
supportedLocales: [
Locale('en'), // English
Locale('de'), // German
],
The localization files are located at lib/l10n/
and can be applied to the package with flutter gen-l10n
.
Change App name with: flutter pub global activate rename
& rename setAppName --targets ios,android,macos,windows,web --value "YourAppName"
You can also set the name for linux, but this isn't the launcher name. Update debians .desktop
file manually.
Generate launcher icons with: flutter pub run flutter_launcher_icons
When you make a new release, this is the targeted procedure.
The versioning scheme is MAJOR.MINOR.PATCH
, increment the:
- MAJOR version when you make substantial API changes or core reworks
- MINOR version when you make any API changes
- PATCH version when you make backward compatible changes
Collect the changes since the previous release and add them to the CHANGELOG.
git log --format=%B v1.0.0..HEAD
Adapt the pubspec.yaml
file. Increment the build number (+1
) behind the version name by one integer.
version: 1.0.0+1
Adapt the lib/core/client.dart
file.
version = "1.0.0"
Tag the commit with a release tag and a 'v' prefix.
git tag v1.0.0
git push --follow-tags
The code is dedicated to the Public Domain as declared in the License.
Contributing to the project implies a copyright release according to the Waiver unless stated otherwise.
You are very welcome to explicitly state your approval with a simple statement such as
Dedicated to Public Domain
in your patches. You can also sign the Waiver with GPG
while listing yourself as Author.
# Generate a GPG key
gpg --full-generate-key
# Optionally export your public key and add it to your Github account and/or a keyserver.
gpg --list-keys
gpg --armor --export <KEYID>
# Sign the waiver
gpg --detach-sig --armor WAIVER.md
# View the signature
cat WAIVER.md.asc
# Verify the signature
gpg --verify WAIVER.md.asc WAIVER.md