1. Required * [x] typespec everything * [x] use structs throughout lib * [x] drop config dir and files * [x] doc everything * [ ] test coverage to 100% * [ ] expand distributed testing to cover more cases 2. Optional * [x] add replication factor support * [x] add callback to refresh cluster