id | title | status | created | category | lead-contributor | contributors | exit-criteria | success-metrics | clear-roles | future-iteration | okrs | |||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
146-status-go-sdk | Status-go-sdk | draft | 2018-04-03 | core | adriacidre |
|
yes | yes | yes | no |
Preamble
Idea: 146-status-go-sdk
Title: Status GO-SDK
Status: In Progress
Created: 2018-04-03
Summary
Provide an easy to use GO-SDK library to allow community developers easily interact with status messaging.
Swarm Participants
- Lead Contributor: @adriacidre
- Contributor: @pilu
- PM: @rachelhamlin
- Testing & Evaluation: @lukaszfryc
Product Overview
Product Description
One of the main goals of status is to grow its community, however is not easy to work on status-go project as a community developer. Is not easy to set up an environment
- Identify where to start
- Interact with status messaging system.
- Test your changes
The idea behind this swarm is to simplify this by allowing community developers to interact with status, based uniquely on status-go library.
Requirements & Dependencies
- Easy to use SDK : Using a sdk should be as easy as using any other messaging system, allowing you to subscribe or publish to specific chats.
- The less dependencies the better : ATM and in order to interact with status messaging system we need to interact with code on status-go and status-react repos. This should be simplified to allow devs work only on top of status-go
- Quick dev environment setup : Following the previous point, if we’re only based on status-go, dev environment should be trivial. Should be easy to build apps and distribute them as binaries for different platforms.
Minimum Viable Product
MVP should allow a developer to accomplish some minimal actions:
- Connect : creates a new connection
- Close : closes active connection
- Auth : login as a specific user
- Subscribe : subscribe to a channel
- Unsubscribe : unsubscribe from a channel
- Publish : send a message.
All methods should work for 1to1, groups and public chats.
With this methods building a simple autoresponder bot
should be as simple as:
TO BE DEFINED
// Connect to the default status url and defer closing the connection
st, _ := status.Connect(st.DefaultAddr) // -> localhost:51515
defer st.Close()
// Authenticate as an specific user
st, _ = status.Auth([]byte(“S3cretT0ken”))
// Subscribes to any message on chat chatID
sub, _ := st.Subscribe("chatID", func(m *st.Msg) {
// Replies the received message
m.Reply([]byte("I can help!”))
sub.Unsubscribe()
})
// Simple message publisher
st.Publish(“buddy_token", []byte("Hello World"))
SDK should be provided with different, easy to follow and well documented examples (TBD):
- Autoresponder bot (nice for testing)
- Google assistant integration
- Slack proxy (use status from slack)
- Reminders (set and get reminders)
Description:
Useful links & Dependencies
- http://offsite.chat
- [https://github.com/mandrigin/status-go-bots](#humans-need-not-apply bots)
- Pre-existing issue
- New protocol spec
- transit-format
- Sniffing app messages
Blockers
New Status App communication protocol - https://github.com/status-im/ideas/issues/87
Dates
Goal Date: TBD
Description: TBD
Testing Days required: TBD
Success Metrics
Milestone 1: Status messaging basic interaction (2018-05-07)
- Setup a new connection
- Ability to close a specific connection
- Ability to change connection configuration
- Ability to sign up on the platform
- Ability to login as a specific account
- Documented API for basic sdk interaction
Milestone 2: Public channels interaction (2018-05-14)
- Ability to join public channels
- Ability to publish messages on public channels
- Ability to subscribe to public channels
- Ability to unsubscribe from a public channel
- Documented API for public channels interaction
- Working examples for public channel interaction
Milestone 3: Contact management (2018-05-21)
Milestone 4: 1 to 1 messages interaction (2018-05-28)
- TBD : Ability to send 1 to 1 conversation
- TBD : Ability to subscribe to 1 to 1 conversation
- TBD : Ability to unsubscribe from a 1 to 1 conversation
- TBD : Documented API for 1 to 1 conversation
- TBD : Working examples for 1 to 1 conversations
Milestone 5: Private groups interaction (2018-06-04)
- TBD : Ability to publish messages on private groups
- TBD : Ability to subscribe to private groups
- TBD : Ability to unsubscribe from a private groups
- TBD : Documented API for private groups interaction
- TBD : Working examples for private groups interaction
Milestone 6: Extra methods (2018-06-11)
- Ability to recover your account
- Ability to log out.
- ...
Exit criteria:
This swarm will be deemed successful and be closed upon the delivery of the above milestones.
Success Metrics
A dev who is unfamiliar with the SDK is able to set up his environment and build a simple chatbot in under 2 hours, just by following the documentation.
Supporting Role Communication
Copyright
Copyright and related rights waived via CC0.