Python SDK for atPlatform
Project description
The atPlatform for Python developers - (Beta Version)
This repo contains library, samples and examples for developers who wish to work with the atPlatform from Python code.
Getting Started
1. Installation
This package can be installed from PyPI with:
pip install atsdk
Alternatively clone this repo and from the repo root:
pip install -r requirements.txt
pip install .
2. Setting up your .atKeys
To run the examples save .atKeys file in the '~/.atsign/keys/' directory.
3. Sending and Receiving Data
There are 3 ways in which data can be sent and received from at server.
-
Using PublicKey
from at_client import AtClient from at_client.common import AtSign from at_client.common.keys import PublicKey atsign = AtSign("@bob") atclient = AtClient(atsign) pk = PublicKey("key", atsign) # Sending data response = atclient.put(pk, "value") print(response) # Receiving Data response = atclient.get(pk) print(response) # Deleting data response = atclient.delete(pk) print(response)
-
Using SelfKey
from at_client import AtClient from at_client.common import AtSign from at_client.common.keys import SelfKey atsign = AtSign("@bob") atclient = AtClient(atsign) sk = SelfKey("key", atsign) # Sending data response = atclient.put(sk, "value") print(response) # Receiving Data response = atclient.get(sk) print(response) # Deleting data response = atclient.delete(sk) print(response)
-
Using SharedKey
from at_client import AtClient from at_client.common import AtSign from at_client.common.keys import SharedKey bob = AtSign("@bob") alice = AtSign("@alice") bob_atclient = AtClient(bob) sk = SharedKey("key", bob, alice) # Sending data response = bob_atclient.put(sk, "value") print(response) # Receiving Data alice_atclient = AtClient(alice) response = alice_atclient.get(sk) print(response) # Deleting data response = bob_atclient.delete(sk) print(response)
CLI Tools
-
REPL - you can use this to type atPlatform commands and see responses; but the best thing about the REPL currently is that it shows the data notifications as they are received. The REPL code has the essentials of what a 'receiving' client needs to do - i.e.
- create an AtClient (assigning a Queue object to its queue parameter)
- start two new threads
- one for the AtClient.start_monitor() task: receives data update/delete notification events (the event data contains the ciphertext)
- the other one calls handle_event() method, which will read the upcoming events in the queue and handle them:
- calling AtClient.handle_event() (to decrypt the notifications and introducing the result as a new event in the queue)
- reading the new event, which contains the decrypted result
- Instructions to run the REPL:
- Run repl.py and choose an atSign using option
1
- Select option
2
. REPL will start and activate monitor mode automatically in a different thread. You can still send commands/verbs. You will start seeing your own notifications (from yourself to yourself) and heartbeat working (noop verb is sent from time to time as a keepalive) - Use
at_talk
or any other tool to send notifications to your atSign from a different atSign. You should be able to see the complete notification, and the encrypted and decrypted value of it.
- Run repl.py and choose an atSign using option
-
REGISTER - use this cli to register new free atsign. Uses onboarding cli to create atkey files.
-
Use following command to run the REGISTER cli using email:
python register.py -e <email>
-
Use following command to run the REGISTER cli using api-key:
python register.py -k <api-key>
-
-
ONBOARDING - use this cli to onboard a new atSign. Once onboarding is complete it creates the all-important keys file. Onboard is a subset of Register.
-
Use following command to run the ONBOARDING cli:
python onboarding.py -a <atsign> -c <cram-secret>
-
-
SHARE - use this cli to share data between 2 atsigns.
-
Use following command to run the SHARE cli:
python share.py -a <atsign> -o <other-atsign> -k <key-name> -s <value>
-
-
GET - use this cli to get shared data between 2 atsigns.
-
Use following command to run the GET cli:
python get.py -a <atsign> -o <other-atsign> -k <key-name>
-
-
DELETE - use this cli to delete any key shared between 2 atsigns.
-
Use following command to run the DELETE cli:
python delete.py -a <atsign> -o <other-atsign> -k <key-name>
-
Open source usage and contributions
This is open source code, so feel free to use it as is, suggest changes or enhancements or create your own version. See CONTRIBUTING.md for detailed guidance on how to setup tools, tests and make a pull request.
Maintainers
This project was created by Umang Shah and is maintained by Chris Swan and Xavier Lin
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
File details
Details for the file atsdk-0.2.28.tar.gz
.
File metadata
- Download URL: atsdk-0.2.28.tar.gz
- Upload date:
- Size: 25.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d4fffed2eaaa9f00bf61b452d5c8a2f1176a4034edd91bbe594fb1e00dded14b |
|
MD5 | 85b1bfd032d0b6d6207b11895a95a562 |
|
BLAKE2b-256 | 9474cc4a86d1ad1e65b90a38d8c3f4a361bb99977f284b9ec851463710be9423 |
File details
Details for the file atsdk-0.2.28-py3-none-any.whl
.
File metadata
- Download URL: atsdk-0.2.28-py3-none-any.whl
- Upload date:
- Size: 32.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5396af616481ce7902c99d31a01c4938162d49624e4b34df8359c9739c48a72c |
|
MD5 | b6acd2f4e1462260756020272abd542a |
|
BLAKE2b-256 | 8da2461ace3d5d5a9bd8c0be6472e5092920992d6c7aa11e79805c1d06423b1b |