2018-07-10 06:15:13 +03:00
|
|
|
/*
|
|
|
|
NAME
|
|
|
|
main.go
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
See Readme.md
|
|
|
|
|
|
|
|
AUTHOR
|
|
|
|
Saxon Nelson-Milton <saxon@ausocean.org>
|
|
|
|
|
|
|
|
LICENSE
|
|
|
|
main.go is Copyright (C) 2017 the Australian Ocean Lab (AusOcean)
|
|
|
|
|
|
|
|
It is free software: you can redistribute it and/or modify them
|
|
|
|
under the terms of the GNU General Public License as published by the
|
|
|
|
Free Software Foundation, either version 3 of the License, or (at your
|
|
|
|
option) any later version.
|
|
|
|
|
|
|
|
It is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with revid in gpl.txt. If not, see [GNU licenses](http://www.gnu.org/licenses).
|
|
|
|
*/
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"log"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"bitbucket.org/ausocean/av/revid"
|
2019-01-02 10:02:20 +03:00
|
|
|
"bitbucket.org/ausocean/iot/pi/smartlogger"
|
|
|
|
"bitbucket.org/ausocean/utils/logger"
|
2018-07-10 06:15:13 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
inputFile = "../../../../test/test-data/av/input/betterInput.h264"
|
|
|
|
frameRate = "25"
|
|
|
|
runDuration = 120 * time.Second
|
2018-09-11 12:06:13 +03:00
|
|
|
logPath = "/var/log"
|
2018-07-10 06:15:13 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
// Test h264 inputfile to flv format into rtmp using librtmp c wrapper
|
|
|
|
func main() {
|
|
|
|
// Get the rtmp url from a cmd flag
|
|
|
|
rtmpUrlPtr := flag.String("rtmpUrl", "", "The rtmp url you would like to stream to.")
|
|
|
|
flag.Parse()
|
|
|
|
if *rtmpUrlPtr == "" {
|
|
|
|
log.Println("No RTMP url passed!")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
config := revid.Config{
|
|
|
|
Input: revid.File,
|
|
|
|
InputFileName: inputFile,
|
|
|
|
InputCodec: revid.H264,
|
2018-12-01 03:47:12 +03:00
|
|
|
Output1: revid.Rtmp,
|
2018-07-10 06:15:13 +03:00
|
|
|
RtmpMethod: revid.LibRtmp,
|
|
|
|
RtmpUrl: *rtmpUrlPtr,
|
|
|
|
Packetization: revid.Flv,
|
2019-01-02 10:02:20 +03:00
|
|
|
Logger: logger.New(logger.Info, &smartlogger.New(logPath).LogRoller),
|
2018-07-10 06:15:13 +03:00
|
|
|
}
|
|
|
|
revidInst, err := revid.New(config, nil)
|
|
|
|
if err != nil {
|
2019-01-02 10:02:20 +03:00
|
|
|
config.Logger.Log(logger.Error, "Should not have got an error!: ", err.Error())
|
2018-07-10 06:15:13 +03:00
|
|
|
return
|
|
|
|
}
|
|
|
|
revidInst.Start()
|
|
|
|
time.Sleep(runDuration)
|
|
|
|
revidInst.Stop()
|
|
|
|
}
|