|
|
@ -109,3 +109,74 @@ func heartbeat(c chan<- ChatAPI, freq time.Duration) { |
|
|
|
count++ |
|
|
|
count++ |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Read fetches chat messages from a conversation. By default, 10 messages will
|
|
|
|
|
|
|
|
// be fetched at a time. However, if count is passed, then that is the number of
|
|
|
|
|
|
|
|
// messages that will be fetched.
|
|
|
|
|
|
|
|
func (c Chat) Read(count ...int) (*ChatAPI, error) { |
|
|
|
|
|
|
|
m := ChatAPI{} |
|
|
|
|
|
|
|
m.Method = "read" |
|
|
|
|
|
|
|
m.Params.Options.Channel = c.Channel |
|
|
|
|
|
|
|
if len(count) == 0 { |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Num = 10 |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Num = count[0] |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
r, err := chatAPIOut(c.keybase.Path, m) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
return &ChatAPI{}, err |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
r.keybase = *c.keybase |
|
|
|
|
|
|
|
return &r, nil |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Next fetches the next page of chat messages that were fetched with Read. By
|
|
|
|
|
|
|
|
// default, Next will fetch the same amount of messages that were originally
|
|
|
|
|
|
|
|
// fetched with Read. However, if count is passed, then that is the number of
|
|
|
|
|
|
|
|
// messages that will be fetched.
|
|
|
|
|
|
|
|
func (c *ChatAPI) Next(count ...int) (*ChatAPI, error) { |
|
|
|
|
|
|
|
m := ChatAPI{} |
|
|
|
|
|
|
|
m.Method = "read" |
|
|
|
|
|
|
|
m.Params.Options.Channel = c.Result.Messages[0].Msg.Channel |
|
|
|
|
|
|
|
if len(count) == 0 { |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Num = c.Result.Pagination.Num |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Num = count[0] |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Next = c.Result.Pagination.Next |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result, err := chatAPIOut(c.keybase.Path, m) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
return &ChatAPI{}, err |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
k := c.keybase |
|
|
|
|
|
|
|
*c = result |
|
|
|
|
|
|
|
c.keybase = k |
|
|
|
|
|
|
|
return c, nil |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Previous fetches the previous page of chat messages that were fetched with Read.
|
|
|
|
|
|
|
|
// By default, Previous will fetch the same amount of messages that were
|
|
|
|
|
|
|
|
// originally fetched with Read. However, if count is passed, then that is the
|
|
|
|
|
|
|
|
// number of messages that will be fetched.
|
|
|
|
|
|
|
|
func (c *ChatAPI) Previous(count ...int) (*ChatAPI, error) { |
|
|
|
|
|
|
|
m := ChatAPI{} |
|
|
|
|
|
|
|
m.Method = "read" |
|
|
|
|
|
|
|
m.Params.Options.Channel = c.Result.Messages[0].Msg.Channel |
|
|
|
|
|
|
|
if len(count) == 0 { |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Num = c.Result.Pagination.Num |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Num = count[0] |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
m.Params.Options.Pagination.Previous = c.Result.Pagination.Previous |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result, err := chatAPIOut(c.keybase.Path, m) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
|
|
|
|
return &ChatAPI{}, err |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
k := c.keybase |
|
|
|
|
|
|
|
*c = result |
|
|
|
|
|
|
|
c.keybase = k |
|
|
|
|
|
|
|
return c, nil |
|
|
|
|
|
|
|
} |
|
|
|