Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ynx0/airlock
Communicate with an Urbit ship over the eyre protocol in Java
https://github.com/ynx0/airlock
java urbit
Last synced: 2 months ago
JSON representation
Communicate with an Urbit ship over the eyre protocol in Java
- Host: GitHub
- URL: https://github.com/ynx0/airlock
- Owner: ynx0
- Created: 2020-11-10T02:25:06.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2021-08-12T19:53:16.000Z (over 3 years ago)
- Last Synced: 2024-10-17T08:33:05.545Z (3 months ago)
- Topics: java, urbit
- Language: Java
- Homepage:
- Size: 510 MB
- Stars: 14
- Watchers: 3
- Forks: 2
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-urbit - Java
README
# Airlock — Java Edition
Communicate with an Urbit ship over the eyre protocol in Java
[![awesome urbit badge](https://img.shields.io/badge/~-awesome%20urbit-lightgrey)](https://github.com/urbit/awesome-urbit)
## Example
```java
public class Main {private static final Gson gson = new Gson();
public static void main(String[] args) {
String url = "http://localhost:8080";
String shipName = "zod";
String code = "lidlut-tabwed-pillex-ridrup";// SETUP
// The following example assumes you have:
// - a ship named 'zod' running
// - a chat channel called 'test' (you must manually create this)// MARK - connect to the ship
Urbit urbit = new Urbit(url, shipName, code);
urbit.authenticate();
urbit.connect();
}
}```
For the most up to date usage examples, see `src/test/java/UrbitIntegrationTestsCore.java` and related.
The file `src/main/java/Main.java` serves as a starting point to experiment with the library,
but may not showcase all features and functionality of the api.## Using
**WARNING: The library is currently in alpha and does not really have a stable api yet. Expect things to break and change**
Currently, the simplest way to play around with the library is to download the source and edit the `Main.java` file yourself.
### Running From Source
1. Clone the repository: `git clone https://github.com/ynx0/urbit`
2. In the cloned repository, run `./gradlew run`. This will run the `Main.java` class.
3. Edit `Main.java` to experiment### Jar
If the code is alpha, using the jar is the greek letter before that. It most likely doesn't work.
To generate a jar from the source, all you have to do is run `./gradlew jar`.However, if you want to try it out, you can download the jar without actually downloading the repository:
1. Go to the [Github Actions](https://github.com/ynx0/urbit/actions) workflows page
2. Find a commit with `Java CI with gradle` underneath that has is passing (has green checkmark).
3. Under the **Artifacts** heading, click on `all-jars`. This will download the jar that was generated from the aforementioned task.## Roadmap
- [x] Minimum viable product
- [x] Basic integration tests
- [x] Github Actions automatically tests on push/pr to `master`
- [x] Basic documentation
- [x] Build javadocs
- [x] Implementation of `scry` and `spider` request types
- [ ] Integration for `scry` and `spider`
- [x] `scry`
- [x] `spider`
- [x] Custom Exceptions for core interface- [x] `graph-store`
- [x] Initial functional implementation of interface
- [x] Graph store tests
- [x] Graph store documentation
- [x] Graph store examples- [ ] Other gall agent interfaces
- [ ] Implementation of surrounding libraries
- [ ] atom manipulation
- [ ] related urbit types### Deprecated
- [ ] Implementation of `chat-store`/`chat-view`
- [ ] Initial functional implementation of interface to agents
- [ ] Graph store tests
- [ ] Graph store documentation
- [ ] Graph store examples### After Stabilization
- [ ] Create example application that uses basic functionality
- [ ] Examples based off of integration tests
- [ ] Create build process (i.e. publishing artifacts to a repository)
- [ ] Soundness tests for various parts of the library (i.e. unit tests)
- [ ] Urbit uid and hexString
- [ ] atom manipulation
- [ ] related urbit types## Prior Art
- Typescript 1 - https://github.com/tylershuster/urbit/
- Typescript 2 - https://github.com/liam-fitzgerald/urbit-airlock-ts
- Go - https://github.com/lukechampine/go-urbit/
- Haskell - https://github.com/bsima/urbit-airlock
- Swift - https://github.com/dclelland/UrsusAirlock/
- channel.js (part of Landscape) - https://github.com/urbit/urbit/blob/master/pkg/arvo/app/landscape/js/channel.js