ssdp

package module
v0.0.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 27, 2024 License: MIT Imports: 14 Imported by: 75

README

SSDP library

PkgGoDev Actions/Go Go Report Card

Based on https://tools.ietf.org/html/draft-cai-ssdp-v1-03.

Examples

There are tiny snippets for example. See also examples/ directory for working examples.

import "github.com/koron/go-ssdp"

ad, err := ssdp.Advertise(
    "my:device",                        // send as "ST"
    "unique:id",                        // send as "USN"
    "http://192.168.0.1:57086/foo.xml", // send as "LOCATION"
    "go-ssdp sample",                   // send as "SERVER"
    1800)                               // send as "maxAge" in "CACHE-CONTROL"
if err != nil {
    panic(err)
}

// run Advertiser infinitely.
quit := make(chan bool)
<-quit
Send alive periodically
import "time"

aliveTick := time.Tick(300 * time.Second)

for {
    select {
    case <-aliveTick:
        ad.Alive()
    }
}
Send bye when quiting
import (
    "os"
    "os/signal"
)

// to detect CTRL-C is pressed.
quit := make(chan os.Signal, 1)
signal.Notify(quit, os.Interrupt)

loop:
for {
    select {
    case <-aliveTick:
        ad.Alive()
    case <-quit:
        break loop
    }
}

// send/multicast "byebye" message.
ad.Bye()
// teminate Advertiser.
ad.Close()
Limitate interfaces to multicast

go-ssdp will send multicast messages to all IPv4 interfaces as default. When you want to limitate interfaces, see below snippet.

import (
    "github.com/koron/go-ssdp"
    "net"
)

en0, err := net.InterfaceByName("en0")
if err != nil {
    panic(err)
}
ssdp.Interfaces = []net.Interface{*en0}

go-ssdp will send multicast message only "en0" after this.

Documentation

Overview

Package ssdp provides SSDP advertiser or so.

Index

Constants

View Source
const (
	// All is a search type to search all services and devices.
	All = "ssdp:all"

	// RootDevice is a search type to search UPnP root devices.
	RootDevice = "upnp:rootdevice"
)

Variables

View Source
var Interfaces []net.Interface

Interfaces specify target interfaces to multicast. If no interfaces are specified, all interfaces will be used.

View Source
var Logger *log.Logger

Logger is default logger for SSDP module.

Functions

func AnnounceAlive

func AnnounceAlive(nt, usn string, location interface{}, server string, maxAge int, localAddr string, opts ...Option) error

AnnounceAlive sends ssdp:alive message. location should be a string or a ssdp.LocationProvider.

func AnnounceBye

func AnnounceBye(nt, usn, localAddr string, opts ...Option) error

AnnounceBye sends ssdp:byebye message.

func SetMulticastRecvAddrIPv4

func SetMulticastRecvAddrIPv4(addr string) error

SetMulticastRecvAddrIPv4 updates multicast address where to receive packets. This never fail now.

func SetMulticastSendAddrIPv4

func SetMulticastSendAddrIPv4(addr string) error

SetMulticastSendAddrIPv4 updates a UDP address to send multicast packets. This never fail now.

Types

type Advertiser

type Advertiser struct {
	// contains filtered or unexported fields
}

Advertiser is a server to advertise a service.

func Advertise(st, usn string, location interface{}, server string, maxAge int, opts ...Option) (*Advertiser, error)

Advertise starts advertisement of service. location should be a string or a ssdp.LocationProvider.

func (*Advertiser) Alive

func (a *Advertiser) Alive() error

Alive announces ssdp:alive message.

func (*Advertiser) Bye

func (a *Advertiser) Bye() error

Bye announces ssdp:byebye message.

func (*Advertiser) Close

func (a *Advertiser) Close() error

Close stops advertisement.

type AliveHandler

type AliveHandler func(*AliveMessage)

AliveHandler is handler of Alive message.

type AliveMessage

type AliveMessage struct {
	// From is a sender of this message
	From net.Addr

	// Type is a property of "NT"
	Type string

	// USN is a property of "USN"
	USN string

	// Location is a property of "LOCATION"
	Location string

	// Server is a property of "SERVER"
	Server string
	// contains filtered or unexported fields
}

AliveMessage represents SSDP's ssdp:alive message.

func (*AliveMessage) Header

func (m *AliveMessage) Header() http.Header

Header returns all properties in alive message.

func (*AliveMessage) MaxAge

func (m *AliveMessage) MaxAge() int

MaxAge extracts "max-age" value from "CACHE-CONTROL" property.

type ByeHandler

type ByeHandler func(*ByeMessage)

ByeHandler is handler of Bye message.

type ByeMessage

type ByeMessage struct {
	// From is a sender of this message
	From net.Addr

	// Type is a property of "NT"
	Type string

	// USN is a property of "USN"
	USN string
	// contains filtered or unexported fields
}

ByeMessage represents SSDP's ssdp:byebye message.

func (*ByeMessage) Header

func (m *ByeMessage) Header() http.Header

Header returns all properties in bye message.

type LocationProvider added in v0.0.4

type LocationProvider interface {
	// Location provides an address be reachable from the network located
	// by "from" address or "ifi" interface.
	// One of "from" or "ifi" must not be nil.
	Location(from net.Addr, ifi *net.Interface) string
}

LocationProvider provides address for Location header which can be reached from "from" address network.

type LocationProviderFunc added in v0.0.4

type LocationProviderFunc func(net.Addr, *net.Interface) string

LocationProviderFunc type is an adapter to allow the use of ordinary functions are location providers.

func (LocationProviderFunc) Location added in v0.0.4

func (f LocationProviderFunc) Location(from net.Addr, ifi *net.Interface) string

type Monitor

type Monitor struct {
	Alive  AliveHandler
	Bye    ByeHandler
	Search SearchHandler

	Options []Option
	// contains filtered or unexported fields
}

Monitor monitors SSDP's alive and byebye messages.

func (*Monitor) Close

func (m *Monitor) Close() error

Close closes monitoring.

func (*Monitor) Start

func (m *Monitor) Start() error

Start starts to monitor SSDP messages.

type Option added in v0.0.5

type Option interface {
	// contains filtered or unexported methods
}

Option is option set for SSDP API.

func AdvertiseHost added in v0.0.5

func AdvertiseHost() Option

AdvertiseHost returns as Option that add HOST header to response for M-SEARCH requests. This option works with Advertise() function only. This is added to support SmartThings. See https://github.com/koron/go-ssdp/issues/30 for details.

func OnlySystemInterface added in v0.0.5

func OnlySystemInterface() Option

OnlySystemInterface returns as Option that using only a system assigned multicast interface.

func TTL added in v0.0.5

func TTL(ttl int) Option

TTL returns as Option that set TTL for multicast packets.

type SearchHandler

type SearchHandler func(*SearchMessage)

SearchHandler is handler of Search message.

type SearchMessage

type SearchMessage struct {
	From net.Addr
	Type string
	// contains filtered or unexported fields
}

SearchMessage represents SSDP's ssdp:discover message.

func (*SearchMessage) Header

func (s *SearchMessage) Header() http.Header

Header returns all properties in search message.

type Service

type Service struct {
	// Type is a property of "ST"
	Type string

	// USN is a property of "USN"
	USN string

	// Location is a property of "LOCATION"
	Location string

	// Server is a property of "SERVER"
	Server string
	// contains filtered or unexported fields
}

Service is discovered service.

func Search(searchType string, waitSec int, localAddr string, opts ...Option) ([]Service, error)

Search searches services by SSDP.

func (*Service) Header

func (s *Service) Header() http.Header

Header returns all properties in response of search.

func (*Service) MaxAge

func (s *Service) MaxAge() int

MaxAge extracts "max-age" value from "CACHE-CONTROL" property.

Directories

Path Synopsis
examples
bye
internal
multicast
Package multicast provides utilities for network multicast.
Package multicast provides utilities for network multicast.
ssdplog
Package ssdplog provides log mechanism for ssdp.
Package ssdplog provides log mechanism for ssdp.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL