{"id":22416427,"url":"https://github.com/liblor/cirrolus","last_synced_at":"2025-03-27T04:20:02.196Z","repository":{"id":85768224,"uuid":"240506686","full_name":"Liblor/Cirrolus","owner":"Liblor","description":"Matriculation Project","archived":false,"fork":false,"pushed_at":"2020-02-14T17:43:34.000Z","size":19,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-02-01T09:29:30.408Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Liblor.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-02-14T12:47:22.000Z","updated_at":"2020-02-14T17:47:04.000Z","dependencies_parsed_at":null,"dependency_job_id":"d645b84e-097a-4c3d-8e47-ec37128b98ac","html_url":"https://github.com/Liblor/Cirrolus","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Liblor%2FCirrolus","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Liblor%2FCirrolus/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Liblor%2FCirrolus/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Liblor%2FCirrolus/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Liblor","download_url":"https://codeload.github.com/Liblor/Cirrolus/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245779485,"owners_count":20670688,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-12-05T15:16:16.093Z","updated_at":"2025-03-27T04:20:02.189Z","avatar_url":"https://github.com/Liblor.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Cirrolus - A P2P-Cloud\n\n\u003cp align=\"center\"\u003e\u003cimg src=\"https://user-images.githubusercontent.com/4940804/74536932-5f5ecd00-4f39-11ea-8630-98da10f63877.png\" alt=\"Cirrolus Logo\"\u003e\u003c/p\u003e\n\nI programmed Cirrolus a P2P-Cloud storage prototype as part of my matriculation project (German: Maturaarbeit).\nIn Switzerland, each student has to do a matriculation project to complete high school.\nA matriculation project is a project in an area of interest of the student which includes a written part and a presentation.\n\nCirrolus is a prototype for a peer-to-peer storage solution, which allows users to upload public and private files.\nA file uploaded is split into, so called, fragments.\nThe approach used is similar to Shamir's secret sharing.\nThat way a node does not possess the original file.\nTherefore, it can not be held accountable for potentially illegal files uploaded.\nFurthermore, multiple fragments are generated and an arbitrary subsets of 4 fragments allow to reassemble the file.\n\nLooking back on this project, I see a lot of room for improvements, but I got a good grade :)\n\n## Usage\n\nStart the program:\n```\n./Cirrolus.py USERNAME [port]\n```\nThe following commands exisit in the interactive prompt.\n```\ndownload FILE\ngetuser\njoin IP [PORT]\nleave\nlist\nsearch [FILENAME]\nsetuser NAME\nupload FILE [p]\n```\n\nTo test the program locally, copy the files into at least 5 different locations.\nStart the program on different ports with different usernames.\nRun `join 127.0.0.1 [Port of one node]` on each node.\nYou should now be able to upload files with `upload FILE` and download it again with `download FILENAME`.\n\n\n## Requirements\n* Python \u003e=2.7\n* PyCrypto (optional)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fliblor%2Fcirrolus","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fliblor%2Fcirrolus","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fliblor%2Fcirrolus/lists"}