This is a component of Papeeria which is responsible for storing file edit history. Its main functions are as follows:
- Keep N latest revisions of every stored text file
- Record changes made by users in the process of file editing
- Replay the sequence of edits starting from some particular revision with an option to reject some of the edits
- Provide "suggestion mode" which allows for one editor to edit his own copy of file with the purpose of merging the changes into the master copy afterwards.
This project was started in March 2018 as a term practice work of the students of Saint-Petersburg Academic University.
This project is internally called Cosmas in the honor of Cosmas of Prague, one of the Slavic chronicle writers. This name also has connotations with Kozma Prutkov
You need JDK 8+ and Gradle 5+. If you're not using gcloud tools, you'll need a JSON credentials file to be able to access Google Cloud Storage and you need to know GCS bucket name. Create your own Google Cloud project and GCS bucket if you're not in Papeeria team.
The following will start Cosmas server on default port 9805 in insecure mode with data stored in papeeria-eu-dev-cosmas
bucket.
$ export GOOGLE_APPLICATION_CREDENTIALS=/path/to/your/credentials/file.json
$ gradle run --args='--bucket papeeria-eu-dev-cosmas'
Branch master
contains code which is considered to be production-ready, that is, at any moment we may decide to build the code from master and push it to production. It must be compilable, it must be operational, it should be tested as much as possible.
If you want to add a new awesome feature, please follow the policy of making changes:
- Create a ticket in the issue tracker and briefly describe the summary of changes.
- Create a branch forked from
master
and namedtkt-ISSUE_NUMBER-MNEMONIC_NAME
whereISSUE_NUMBER
is the number of issue created on the previous setp andMNEMONIC_NAME
is short mnemonic name for managing the khaos of branches. Example:tkt-1-proto-file
- Commit your changes to the branch. When you get something that compiles, works as intended (or vice versa, is not involved in the operational process at all) and doesn't break the existing functionality, create a pull request and wait for code review. The smaller is the number of changes the better. As a rule of thumb, changing up to 500 lines of code is okay, up to 1000 is acceptable. If you changed more than 1000 lines of code then you probably made something wrong, either from coding of from change process prespective and you should consider refactorign your code and breaking it into smaller pieces.
- It is not required that pull request completely implements what is written in the ticket.
- It is okay to create many sequential pull requests per single ticket
- It is okay to send pull request with no unit tests, however, we appreciate writing "tests are coming" in the pull request summary if you plan to add them later
- Once code review is started, please do not add anything besides unit tests and changes requested by reviewers to your branch. If you add some 500 LOC in addition to already reviewed then review essentially starts from scratch and the process never converges. We want
tkt-
branches to be merged as soon as possible. - You will get a lot of comments in the review. Please reply to every comment with either single word "Done" if you agree with the comment and made the requested changes or with something more verbose. Replying is a way to ensure both yourself and reviewer that you don't miss or didn't ignore any comment.
- There are so called "pending reviews" in GitHub which is a great way to write comments without sending them and send the batch of comments later. This way you can read the review comments, change your code, comment "done", proceed to the next comment and once you are done, commit changes in the code, push and then send your replies. It makes commenting meaningful and less spammy: reviewer will receive a single email and he will be sure that everything which is "done" is actually done and sits in the repository.