cmd/stream.go
author Mikael Berthe <mikael@lilotux.net>
Mon, 08 May 2017 20:31:29 +0200
changeset 103 7a4604bb12d9
parent 81 b1671f83e91b
child 110 57843255fd1a
permissions -rw-r--r--
Fix panic when a streaming connection is closed (in multi-streams) tagDone channels were not initialized for multiple tags streams.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     1
// Copyright © 2017 Mikael Berthe <mikael@lilotux.net>
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     2
//
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     3
// Licensed under the MIT license.
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     4
// Please see the LICENSE file is this directory.
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     5
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     6
package cmd
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     7
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     8
import (
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
     9
	"io"
47
82d8b6074309 Set exit code to non-zero when API calls fail
Mikael Berthe <mikael@lilotux.net>
parents: 45
diff changeset
    10
	"os"
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    11
	"strings"
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    12
45
b58a7ea1aeb2 Use github.com/pkg/errors
Mikael Berthe <mikael@lilotux.net>
parents: 44
diff changeset
    13
	"github.com/pkg/errors"
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    14
	"github.com/spf13/cobra"
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    15
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    16
	"github.com/McKael/madon"
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    17
)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    18
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    19
/*
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    20
var streamOpts struct {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    21
	local bool
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    22
}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    23
*/
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    24
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    25
// Maximum number of websockets (1 hashtag <=> 1 ws)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    26
const maximumHashtagStreamWS = 4
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    27
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    28
// streamCmd represents the stream command
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    29
var streamCmd = &cobra.Command{
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    30
	Use:   "stream [user|local|public|:HASHTAG]",
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    31
	Short: "Listen to an event stream",
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    32
	Long: `
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    33
The stream command stays connected to the server and listen to a stream of
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    34
events (user, local or federated).
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    35
It can also get a hashtag-based stream if the keyword or prefixed with
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    36
':' or '#'.`,
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    37
	Example: `  madonctl stream           # User timeline stream
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    38
  madonctl stream local     # Local timeline stream
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    39
  madonctl stream public    # Public timeline stream
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    40
  madonctl stream :mastodon # Hashtag
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    41
  madonctl stream #madonctl
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    42
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    43
Several (up to 4) hashtags can be given.
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    44
Note: madonctl will use 1 websocket per hashtag stream.
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    45
  madonctl stream #madonctl,#mastodon,#golang
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    46
  madonctl stream :madonctl,mastodon,api`,
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    47
	RunE:       streamRunE,
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    48
	ValidArgs:  []string{"user", "public"},
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    49
	ArgAliases: []string{"home"},
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    50
}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    51
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    52
func init() {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    53
	RootCmd.AddCommand(streamCmd)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    54
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    55
	//streamCmd.Flags().BoolVar(&streamOpts.local, "local", false, "Events from the local instance")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    56
}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    57
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    58
func streamRunE(cmd *cobra.Command, args []string) error {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    59
	streamName := "user"
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    60
	tag := ""
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    61
	var hashTagList []string
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    62
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    63
	if len(args) > 0 {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    64
		if len(args) != 1 {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    65
			return errors.New("too many parameters")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    66
		}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    67
		arg := args[0]
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    68
		switch arg {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    69
		case "", "user":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    70
		case "public":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    71
			streamName = arg
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    72
		case "local":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    73
			streamName = "public:local"
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    74
		default:
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    75
			if arg[0] != ':' && arg[0] != '#' {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    76
				return errors.New("invalid argument")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    77
			}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    78
			streamName = "hashtag"
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    79
			tag = arg[1:]
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    80
			if len(tag) == 0 {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    81
				return errors.New("empty hashtag")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    82
			}
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    83
			hashTagList = strings.Split(tag, ",")
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    84
			for i, h := range hashTagList {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    85
				if h[0] == ':' || h[0] == '#' {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    86
					hashTagList[i] = h[1:]
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    87
				}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    88
				if h == "" {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    89
					return errors.New("empty hashtag")
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    90
				}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    91
			}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    92
			if len(hashTagList) > maximumHashtagStreamWS {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    93
				return errors.Errorf("too many hashtags, maximum is %d", maximumHashtagStreamWS)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
    94
			}
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    95
		}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    96
	}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    97
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    98
	if err := madonInit(true); err != nil {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
    99
		return err
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   100
	}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   101
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   102
	evChan := make(chan madon.StreamEvent, 10)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   103
	stop := make(chan bool)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   104
	done := make(chan bool)
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   105
	var err error
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   106
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   107
	if streamName != "hashtag" || len(hashTagList) <= 1 { // Usual case: Only 1 stream
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   108
		err = gClient.StreamListener(streamName, tag, evChan, stop, done)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   109
	} else { // Several streams
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   110
		n := len(hashTagList)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   111
		tagEvCh := make([]chan madon.StreamEvent, n)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   112
		tagDoneCh := make([]chan bool, n)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   113
		for i, t := range hashTagList {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   114
			if verbose {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   115
				errPrint("Launching listener for tag '%s'", t)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   116
			}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   117
			tagEvCh[i] = make(chan madon.StreamEvent)
103
7a4604bb12d9 Fix panic when a streaming connection is closed (in multi-streams)
Mikael Berthe <mikael@lilotux.net>
parents: 81
diff changeset
   118
			tagDoneCh[i] = make(chan bool)
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   119
			e := gClient.StreamListener(streamName, t, tagEvCh[i], stop, tagDoneCh[i])
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   120
			if e != nil {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   121
				if i > 0 { // Close previous connections
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   122
					close(stop)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   123
				}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   124
				err = e
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   125
				break
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   126
			}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   127
			// Forward events to main ev channel
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   128
			go func(i int) {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   129
				for {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   130
					select {
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   131
					case _, ok := <-tagDoneCh[i]:
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   132
						if !ok { // end of streaming for this tag
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   133
							done <- true
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   134
							return
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   135
						}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   136
					case ev := <-tagEvCh[i]:
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   137
						evChan <- ev
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   138
					}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   139
				}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   140
			}(i)
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   141
		}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   142
	}
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   143
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   144
	if err != nil {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   145
		errPrint("Error: %s", err.Error())
47
82d8b6074309 Set exit code to non-zero when API calls fail
Mikael Berthe <mikael@lilotux.net>
parents: 45
diff changeset
   146
		os.Exit(1)
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   147
	}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   148
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   149
	p, err := getPrinter()
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   150
	if err != nil {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   151
		close(stop)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   152
		<-done
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   153
		close(evChan)
81
b1671f83e91b Do not display usage when GetPrinter fails
Mikael Berthe <mikael@lilotux.net>
parents: 74
diff changeset
   154
		errPrint("Error: %s", err.Error())
b1671f83e91b Do not display usage when GetPrinter fails
Mikael Berthe <mikael@lilotux.net>
parents: 74
diff changeset
   155
		os.Exit(1)
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   156
	}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   157
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   158
LISTEN:
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   159
	for {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   160
		select {
103
7a4604bb12d9 Fix panic when a streaming connection is closed (in multi-streams)
Mikael Berthe <mikael@lilotux.net>
parents: 81
diff changeset
   161
		case v, ok := <-done:
7a4604bb12d9 Fix panic when a streaming connection is closed (in multi-streams)
Mikael Berthe <mikael@lilotux.net>
parents: 81
diff changeset
   162
			if !ok || v == true { // done is closed, end of streaming
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   163
				break LISTEN
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   164
			}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   165
		case ev := <-evChan:
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   166
			switch ev.Event {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   167
			case "error":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   168
				if ev.Error != nil {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   169
					if ev.Error == io.ErrUnexpectedEOF {
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   170
						errPrint("The stream connection was unexpectedly closed")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   171
						continue
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   172
					}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   173
					errPrint("Error event: [%s] %s", ev.Event, ev.Error)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   174
					continue
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   175
				}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   176
				errPrint("Event: [%s]", ev.Event)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   177
			case "update":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   178
				s := ev.Data.(madon.Status)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   179
				p.PrintObj(&s, nil, "")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   180
				continue
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   181
			case "notification":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   182
				n := ev.Data.(madon.Notification)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   183
				p.PrintObj(&n, nil, "")
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   184
				continue
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   185
			case "delete":
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   186
				// TODO PrintObj ?
44
6da40ca4534c Sync with Madon; switch IDs to int64 integers
Mikael Berthe <mikael@lilotux.net>
parents: 0
diff changeset
   187
				errPrint("Event: [%s] Status %d was deleted", ev.Event, ev.Data.(int64))
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   188
			default:
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   189
				errPrint("Unhandled event: [%s] %T", ev.Event, ev.Data)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   190
			}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   191
		}
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   192
	}
74
78e1c63e4bbe Add support for several hashtag streams
Mikael Berthe <mikael@lilotux.net>
parents: 47
diff changeset
   193
	close(stop)
0
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   194
	close(evChan)
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   195
	return nil
5abace724584 Initial public release
Mikael Berthe <mikael@lilotux.net>
parents:
diff changeset
   196
}