futzu / gumd

gumd is a Multicast (UDP) Stream Sender. gumc is a Multicaast(UDP) Stream Client. Up and running in 3 lines of code, or it's Free.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

project super kabuki SCTE-35 Packet Injection

Grande Unified M ulticast D aemon,

&

Grande Unified M ulticast C lient,


" I've been googling for some time now, and still have yet to find a working example of Python multicast"

~ said everyone before gumd


Latest is v.0.0.9

  • Install
python3 -mpip install gumd

Use gumd (Daemon) programmatically

>>>> from gumd import GumD
>>>> gumd =GumD('235.35.3.5:3535',1)
>>>> gumd.mcast("/home/a/stuff")
stream uri: udp://@235.35.3.5:3535
>>>>

Use gumc (Client) programmatically

>>>> from gumc import GumC
>>>> gumc = GumC("udp://@235.35.3.5:3535")
>>>> data = gumc.read(8)
>>>> data
b'Helloooo'

Cli tools

  • The cli tools gumd and gumc try to install to ~/.local/bin
  • make sure ~/.local/bin is in your path I have this at the end my .bashrc
PLAN9=/home/a/plan9port export PLAN9
PATH=/home/a/.local/bin:$PLAN9:$PATH export PATH

if you dont get them installed, roll your own.

  • gumd (Daemon)
  #!/usr/bin/env python3

  from gumd import cli 

  cli()
  • gumc (Client)
  #!/usr/bin/env python3

  from gumc import cli 

  cli()

Install cli tools


install gumd /usr/local/bin  # or ~/.local/bin
install gumc /usr/local/bin  # or ~/.local/bin


Use gumd (Daemon) cli

  • Supported input mpegts URIs:

    • files gumd -i /home/me/vid.ts
    • http(s) gumd -i https://futzu.com/xaa.ts
    • multicast gumd -i udp://@235.1.2.3:4567
    • reading from stdin cat myvideo.ts | gumd
usage: gumd [-h] [-i INPUT] [-a ADDR] [-t TTL] [-v]

options:

-h, --help            show this help message and exit

-i INPUT, --input INPUT
                        like "/home/a/vid.ts" or
                        "udp://@235.35.3.5:3535" or
                        "https://futzu.com/xaa.ts"
-a ADDR, --addr ADDR  like "227.1.3.10:4310"
-t TTL, --ttl TTL     1 - 255
-v, --version         Show version

start gumd (Daemon) cli

a@debian:~/gumd$ gumd -i /home/a/abc.py 
stream uri: udp://@235.35.3.5:3535
a@debian:~/gumd$ 

use gumc (Client) cli

usage: gumc [-h] [-i INSTUFF] [-b BYTESIZE] [-v]

options:
  -h, --help            show this help message and exit
  -i INSTUFF, --instuff INSTUFF
                        default is 'udp://@235.35.3.5:3535'
  -b BYTESIZE, --bytesize BYTESIZE
                        Number of bytes to read. default is 1
  -v, --version         Show version

start gumc (Client) cli

a@debian:~/build/clean/gumd$ gumc -i udp://@235.35.3.5:3535 -b 1024

Test gumd and gumc together

  • first terminal, start the client, gumc
a@debian:~/build/clean/gumd$ pypy3 gumc.py -b 5 -i udp://@235.35.3.5:3535
  • second terminal,start the daemon, gumd__ and send a "hello"
a@debian:~/build/clean/gumd$ printf 'hello' | gumd -a 235.35.3.5:3535
stream uri: udp://@235.35.3.5:3535

play gumd (Daemon) stream with ffplay

ffplay udp://@235.35.3.5:3535

segment stream from gumd (Daemon) into hls with x9k3

pypy3 x9k3.py -i udp://@235.35.3.5:3535

read 13 bytes from a multicast stream with gumc (Client)

gumc -i udp://@235.35.3.5:3535 -b 13

read 10000 bytes from a multicast stream with gumc (Client)

 gumc -i udp://@235.35.3.5:3535 -b 13

Note: a multicast client works a little differently than most people expect.

You must specify a size to read or the client will never return.

image

About

gumd is a Multicast (UDP) Stream Sender. gumc is a Multicaast(UDP) Stream Client. Up and running in 3 lines of code, or it's Free.


Languages

Language:Python 100.0%