-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparams.json
7 lines (7 loc) · 11.6 KB
/
params.json
1
2
3
4
5
6
7
{
"name": "FFII.Github.io",
"tagline": "FFII Developer Site",
"body": "# FFII Software Projects\r\n* [Groff Typesetting](http://groff.ffii.org)\r\n* [Parliament Data Information System](http://parltrack.euwiki.org)\r\n* [CJK Internationalisation of Text Processing](http://lists.ffii.org/mailman/listinfo/cjk)\r\n* [Crypto-Stick for Encrypted Key Communication](https://tasks.ffii.org/projects/cryptostick)\r\n* [TIO Open Cloud Infrastructure](https://lists.ffii.org/mailman/listinfo/tio)\r\n* [GAUSS Patent Information System (scheduled maintenance until March 5, 2015)](http://gauss.ffii.org)\r\n* [Multilingual Hypertext](https://lists.ffii.org/mailman/listinfo/mlhtapp-help)\r\n\r\n\r\n#Ideas\r\nBelow are projects, where we are looking for contributions of students. There are some ideas for developments, but we love to get your own ideas as well. If you have a project that is in line with our mission of free information infrastructures, please feel free to propose one. You can make a pull request and add your idea to this list at https://github.com/ffii/ffii.github.io\r\n\r\n## Groff (GNU troff) Typesetting\r\nGroff is a typesetting system that reads plain text mixed with formatting commands and produces formatted output. Output may be PostScript or PDF, html, or ASCII/UTF8 for display at the terminal. Formatting commands may be either low-level typesetting requests (“primitives”) or macros from a supplied set. Users may also write their own macros. All three may be combined. Present on most Unix systems owing to its long association with Unix manuals (manpages), groff is capable of producing typographically sophisticated documents while consuming only minimal system resources. \r\n* License: GNU General Public License.\r\n* Mentors: User issues lead: Ted Harding, Technical issues lead: Werner Lemberg\r\n* Code: https://savannah.gnu.org/git/?group=groff\r\n* Website: http://groff.ffii.org\r\n* Mailing List: http://lists.gnu.org/mailman/listinfo/groff/\r\n* Issue Tracker: https://savannah.gnu.org/projects/groff/\r\n\r\n### Project 1\r\nTask: Let document define kern pairs, including between characters in different fonts \r\nDetails: Groff should allow a document author to define new kern pairs, including ones between characters from different fonts. This functionality is available in Heirloom troff's .kernpair request. \r\n\r\n### Project 2\r\nTask: Provide a way to redefine an existing symbol in a specific font \r\nDetails: When searching for a symbol, groff first checks whether the symbol has been defined with the .char request. If not, it checks the current font. Only if it is not in the current font does groff check other user-defined symbols. Thus, while .char can override an existing symbol across all fonts, there is no way to override an existing symbol only in a specific font, because all other symbol rules are of lower precedence than checking the current font. The mailing list thread beginning with http://lists.gnu.org/archive/html/groff/2015-02/msg00029.html contains examples of situations where this lack of functionality makes performing certain tasks ponderous. \r\n\r\n### Project 3\r\nTask: Improve Unicode support \r\n\r\n### Project 4\r\nTask: Implement shrinkable space \r\nDetails: Perhaps the third entry in the list of the most important improvements to GNU troff: shrinkable space. I guess that this has to be implemented while adding support for TeX-like paragraph formatting \r\n\r\n### Project 5\r\nTask: Modernize Font Support \r\nDetails: Update to today's font world. What groff currently supports natively (PostScript Type 1) is out of date since 15 years. Heirloom troff has support for this. http://heirloom.sourceforge.net/doctools.html \r\n\r\n## Parliament Data Information Systems\r\nParltrack is a European initiative to improve the transparency of legislative processes. It combines information on dossiers, representatives, vote results and committee agendas into a unique database and allows the tracking of dossiers using email and RSS. Most of the data presented is also available for further processing in JSON format. Using Parltrack it's easy to see at a glance which dossiers are being handled by committees and MEPs.\r\n* License: Affero GPL v3+\r\n* Mentors: Andre Rebentisch\r\n* Code: https://github.com/pudo/parltrack/\r\n* Website: http://parltrack.euwiki.org\r\n* Mailing List: https://lists.ffii.org/mailman/listinfo/mepdb-parl\r\n\r\n### Project 1\r\nTask: Implement Open Data Visualizations of Parliament Decisions \r\nTechnologies: JSON, HTML, Shell Script, Linux, API, Maps, Google Map, OpenStreetMap\r\n\r\n### Project 2\r\nTask: Automate regular Data Dumps in an Exchangeable Format \r\nTechnologies: JSON, Shell Script, Python, Django, Database, NoSQL, SQL\r\n\r\n## CJK Internationalisation of Text Processing\r\nCJK stands for \"Chinese, Japanese, Korean\". The goal of the FFII project for Internationalisation of Text Processing is to embed Asian text into texts document using the Latin alphabet. There is also CJK version version available as a LaTeX 2e macro package release which enables the use of CJK scripts (Chinese/Japanese/Korean) in various encodings, written by Werner Lemberg. With Mule (multilingual Emacs) you can write texts in multiple languages. This editor is especially designed to handle the various encodings and character sets of Asian scripts such as Big 5 and GB for Chinese, JIS for Japanese, etc. Even more, you can use multiple CJK character sets simultaneously which enables e.g. Chinese users to write simplified (jiˇantˇız`ı 简体字) and traditional Chinese characters (f ́antˇız`ı 繁體字) at the same time. An article about the CJK package can be found in [TUGBoat](http://tug.org/TUGboat/Articles/tb18-3/cjkintro600.pdf).\r\n* License: GNU General Public License.\r\n* Mentor: Hartmut Pilch\r\n* Code: http://cjk.ffii.org/cjk-4.8.3.tar.gz\r\n* Website: http://cjk.ffii.org\r\n* Mailing List: http://lists.ffii.org/mailman/listinfo/cjk\r\n\r\n### Project 1\r\nTask: Implement new commands for typical use. See the example file `CJKfntef.tex' \r\nTechnologies: Command Line, Internationalization, UTF8 Standardization, Linux, Latex\r\n\r\n### Project 2\r\nTask: Implement support of Emacs version above 23 \r\nTechnologies: Command Line, Internationalization, UTF8 Standardization, Linux, Latex\r\n\r\n### Project 3\r\nTask: Implement support for Khmer and Vietnamese for UTF-8 encoding, making emacs \r\nTechnologies: Command Line, Internationalization, UTF8 Standardization, Linux, Latex\r\n\r\n## Crypto-Stick for Encrypted Key Communication\r\nThe Crypto Stick is a USB stick in a small form factor containing an integrated OpenPGP smart card to allow easy and high-secure encryption e.g. of e-mail or for authentication in network environments. As opposed to ordinary software solutions, private keys are always inside the Crypto Stick so that their exposure is impossible. All cryptographic operations (precisely: decryption and signature because of public key cryptography) are executed on the PIN-protected Crypto Stick. In case the Crypto Stick was stolen, got lost, or is used on a virus-contaminated computer (e.g. Trojan horse) no attacker is able to access the private keys so that all encrypted data stays secure. The Crypto Stick is developed as a non-profit open source project and ensures a very high level of security due to verifiability and an attractive price. The open interface of the used OpenPGP smart card allows optimal compatibility with various software applications (e.g. GnuPG, Mozilla Thunderbird + Enigmail, OpenSSH, Linux PAM, OpenVPN, Mozilla Firefox).\r\n* License: Different Open Source Licenses\r\n* Mentor: Jan Suhr\r\n* Project Site: https://tasks.ffii.org/projects/cryptostick\r\n* Code: https://www.assembla.com/spaces/cryptostick\r\n* Mailing List: https://lists.ffii.org/mailman/listinfo/crypto\r\n\r\n### Project 1\r\nTask: One Time Password Optimization \r\nDetails: The current One Time Password (OTP) implementation doesn't encrypt the secrets in the Crypto Stick. (Earlier it was planned to trigger the OTP with a dedicated button only). Now the firmware should be improved so that the secrets are encrypted with the embedded smart card. In addition, mechanisms to prevent the creation of large amounts of tokens should be prevented.The challenge-responds version of OTP called OCRA should be implemented. \r\nTo do:\r\n* Integrate the smart card to encrypt and decrypt the OTP secrets \r\n* Add throttling mechanisms\r\n* Add OCRA feature to OTP\r\n* Update the client tool to support OCRA, potentially create a FireFox addon for this purpose\r\n* Test\r\n\r\n### Project 2\r\nTask: Support for Google's U2F (FIDO Alliance) - Implement support for the FIDO Alliance's U2F token \r\nDetails:\r\n* Get familiar with the U2F specification \r\n* Draft an approach to integrate U2F to the Crypto Stick \r\n* Implement U2F to the firmware \r\n* Implement U2F support into the Crypto Stick Tool \r\n* Test \r\n\r\n### Project 3\r\nTask: L4-Based Secure eCash Server \r\nDetails: OpenCoin is a related open source project to build an anonymous digital cash system. L4 is a microkernel for secure embedded environments. This project is to implement a secure server for OpenCoin based on L4re. The server would perform the following activities: receive a token, verify its integrity, create a new token, sign it by calling a HSM, store the old token in an external DB, send back the new token. \r\nTo do:\r\nG* et familiar with the OpenCoin protocol and L4re. \r\n* Agree the architecture with mentor \r\n* Implement the external interfaces \r\n* Implement JSON parsing and token structures etc. \r\n* Implement SHA2 hashing and RSA signature validation, preferrable by utilizing existing libraries.\r\n* Port and integrate existing PKCS#11 driver to L4re \r\n* Documentation, testing\r\n\r\n### Project 4\r\nTask: OpenPGP JavaCard \r\nDetails: Re-implement the OpenPGP Card specification on a JavaCard device. A project space has already been setup here but this implementation seems to be more mature. \r\n\r\n### Project 5\r\nTask: Secure firmware update \r\nDetails: The purpose is to prevent (or make it more difficult) flashing of malicious firmware when an attacker has access to the device for a short time. Legitimate firmwares would be signed with a firmware signing key. Crypto Stick would be shipped with the public signing key. User downloads a signed firmware update for their device, and loads it onto the Crypto Stick. Crypto Stick verifies the signature, ensuring that the firmware is authentic. If it is, the firmware updates itself, otherwise it rejects it. The entire logic might be implemented in a separate boot loader either for the current STM32-based Crypto Stick 1.4 or for the new Crypto Stick 2 which is Atmel AT43UC-based. \r\nTo do:\r\n* Get familiar with Crypto Stick's firmware.\r\n* Decide for a bootloader to use\r\n* Get the bootloader running\r\n* Integrate hash- and RSA signature verification functions\r\n* Implement load-firmware function\r\n* If necessary: write client tool to send new firmware to Crypto Stick\r\n* Test \r\n\r\n# About FFII\r\nThe FFII, Foundation for Free Information Infrastructures, is a not-for-profit association active in over fifty countries, dedicated to the development of information goods for the public benefit, based on copyright, free competition, and open standards. More than 1000 members, 3,500 companies and 100,000 supporters have entrusted the FFII to act as their voice in public policy questions concerning exclusion rights in data processing. \r\n* http://ffii.org\r\n* http://blog.ffii.org\r\n* http://tasks.ffii.org",
"google": "",
"note": "Don't delete this file! It's used internally to help with page regeneration."
}