An implementation of a WebSocket authentication scheme, unsecured ws://
Project description
sb_auth (seqbuild Authenticator)
Work in progress
A WebSocket authentication schematic for a client-server model, using the seqbuild library.
Simple client-server layout. Authentication allows for file read/write operations to take place between the two devices.
NOTE
The current websocket implementation uses the unsecured ws:// protocol instead of the
secured wss:// one. The development of this authenticator has not advanced into
production-level mode.
This codebase works for local WiFi networks but otherwise, more code with third-party services must be used for secured communication.
Description
There are three perspectives for use:
- local (server or client side): offline mode, used to modify read/write settings and delete bunk Comm Lang key files.
- server: can serve an unspecified number of clients. Every authenticated client has read/write access to permitted files/folders.
- client: can access one server at a time to read/write permitted files.
The procedure in which a client interacts with a server goes so:
- Client sends IP address and port number (default is 8765, variable<DEFAULT_PORT>), and connects to the server.
- Client inputs username. If server has no registered username, it sends client a new
Comm Lang file key. This is a script that loads up a primary pseudo-random number generator
G, and can be executed by
seqbuild's Comm Lang interpreter. Client stores this Comm Lang file key and sets the number of past iterationsi_pto 0. - Client is required to output
q_xintegers from generator G,q_xspecified by the server and in the range ofDEFAULT_SB_AUTH_KEYSIZE_RANGE, default set to[24,58], every time client prompts to read/write a file;q_xis variable. Theseq_xintegers are sent to the server, and the server terminates connection if those integers do not match the ones it calculated, given the same Comm Lang file key. - When the number of past iterations
i_pof G passes a numberq2, specified by the server and in the range ofDEFAULT_SB_AUTH_INDEX_RANGE, default set to[627,1450), server sends client a new Comm Lang file key. Integerq2is set by the server when client connects to it, and remains constant throughout the session.
Server does not require any user input. Client requires user to input IP address/port, as well as for read/write operations to permitted files.
On the server side, every username it has stored in its client directory is associated with a file for file+folder exclusions. These exclusions prohibit the client from read/write operations concerning them.
Default File Naming
-
Server Side:
- username directory file is @
user_data/server_dir. - directory file stores Comm Lang key file names and generator index (number of past iterations) for every username.
- directory file column layout is
- username
- Comm Lang key filepath
- primary generator name
- generator index
- number of sessions key has been used
- every username
Uhas a Comm Lang file key @user_data/commond_U.txt. - default permissions file is @
user_data/default_user_permissions.txt. - every username
Uhas an exclusion file @user_data/permissions_U.txt.
- username directory file is @
-
Client Side:
- username directory file is @
user_data/client_dir. - column layout is virtually identical to that of server side.
- every server of IP address
Iand portQis assigned a Comm Lang key file.
- username directory file is @
The Identity Aspect
Websocket has the problem of authentication. If a username's Comm Lang file key for a
server is shared between > 1 devices, those devices can all access the server under
the same username.
For a server with a fixed IP address and port combination, a device can access it through only one username, given how the file naming convention goes.
Technicals Behind the Generator Key
The program used to generate Comm Lang key files is seqbuild @
seqbuild. Specifically, the Comm Lang file
generator is @ the file face/easy_gen_struct.py. There may be instances where the key
may be a generator such that two different devices output different sequences of integers.
So the Comm Lang key file generator is not guaranteed to be stable.
Usage
Go into this directory, and run this script:
from sb_auth.exec import *
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file sb_auth-0.0.2.tar.gz.
File metadata
- Download URL: sb_auth-0.0.2.tar.gz
- Upload date:
- Size: 15.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
902e2770b25239bca3f22a4cdde1ae6107449cd82d7bfcf174ee3ca56f544421
|
|
| MD5 |
a6b5497621362063f6d612803d8318af
|
|
| BLAKE2b-256 |
0b14479da54438ee13d9e2ca97b86210d6e854a71f6ad09c81ef5ab017237ea6
|
File details
Details for the file sb_auth-0.0.2-py3-none-any.whl.
File metadata
- Download URL: sb_auth-0.0.2-py3-none-any.whl
- Upload date:
- Size: 15.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f1880372e74a84fb4f310467f45ac462026993e00facba0614c2bba817d1dcdb
|
|
| MD5 |
26e5d75f15bf57c2cef1173aec803e6a
|
|
| BLAKE2b-256 |
32fd785a6a75a8d3e27ec37a6300214bcebc905b5c0ea79f59c9c0f1bca3044b
|