Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/migeyel/ccryptolib
https://github.com/migeyel/ccryptolib
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/migeyel/ccryptolib
- Owner: migeyel
- License: mit
- Created: 2023-06-08T04:22:43.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-10-29T22:45:23.000Z (8 months ago)
- Last Synced: 2024-01-25T19:37:24.816Z (5 months ago)
- Language: Lua
- Size: 1.32 MB
- Stars: 8
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Lists
- awesome-switchcraft - ccryptolib - Collection of cryptographic primitives written in Lua (Libraries / Utility)
README
# CCryptoLib
An integrated collection of cryptographic primitives written in Lua using the ComputerCraft system API.## Initializing the Random Number Generator
All functions that take secret input may query the library's random generator,
`ccryptolib.random`. CC doesn't have high-quality entropy sources, so instead of
hoping for the best like other libraries do, CCryptoLib shifts that burden into
*you!*If you trust the tmpim Krist node, you can fetch a socket token and use it for
initialization:
```lua
local random = require "ccryptolib.random"-- Fetch a WebSocket token.
local postHandle = assert(http.post("https://krist.dev/ws/start", ""))
local data = textutils.unserializeJSON(postHandle.readAll())
postHandle.close()-- Initialize the generator using the given URL.
random.init(data.url)-- Be polite and actually open the socket too.
http.websocket(data.url).close()
```Otherwise, you will need to find another high-quality random entropy source to
initialize the generator. **DO NOT INITIALIZE USING MATH.RANDOM.**