From ece69efd67af2982cac882b9192872c7ff6957bb Mon Sep 17 00:00:00 2001 From: Christian Pointner Date: Thu, 3 Dec 2015 19:59:01 +0100 Subject: moved control interface back to main package added importer at rhimport package diff --git a/Makefile b/Makefile index a33f9d7..5de8b45 100644 --- a/Makefile +++ b/Makefile @@ -32,10 +32,12 @@ getlibs: vet: export GOPATH=$(curdir) vet: $(GOCMD) vet helsinki.at/rhimportd + $(GOCMD) vet helsinki.at/rhimport format: export GOPATH=$(curdir) format: $(GOCMD) fmt helsinki.at/rhimportd + $(GOCMD) fmt helsinki.at/rhimport build: export GOPATH=$(curdir) build: getlibs diff --git a/src/helsinki.at/rhimport/importer.go b/src/helsinki.at/rhimport/importer.go new file mode 100644 index 0000000..5da6075 --- /dev/null +++ b/src/helsinki.at/rhimport/importer.go @@ -0,0 +1,99 @@ +// +// rhimportd +// +// The Radio Helsinki Rivendell Import Daemon +// +// +// Copyright (C) 2015 Christian Pointner +// +// This file is part of rhimportd. +// +// rhimportd is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// any later version. +// +// rhimportd 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 rhimportd. If not, see . +// + +package rhimport + +import ( + // "bytes" + "fmt" + // "io" + // "mime/multipart" + // "net/http" + // "os" +) + +type ImportContext struct { + username string + groupname string + // TODO: password channel + cart int + channels int + normalization_level int + autotrim_level int + use_meta_data bool + source_file string + delete_source_file bool +} + +// func import_audio(url, file string) (err error) { + +// var b bytes.Buffer +// w := multipart.NewWriter(&b) + +// if err = w.WriteField("COMMAND", "2"); err != nil { +// return +// } +// if err = w.WriteField("LOGIN_NAME", ""); err != nil { +// return +// } +// if err = w.WriteField("PASSWORD", ""); err != nil { +// return +// } + +// f, err := os.Open(file) +// if err != nil { +// return +// } +// fw, err := w.CreateFormFile("FILENAME", file) +// if err != nil { +// return +// } +// if _, err = io.Copy(fw, f); err != nil { +// return +// } +// f.Close() + +// w.Close() + +// req, err := http.NewRequest("POST", url, &b) +// if err != nil { +// return +// } +// req.Header.Set("Content-Type", w.FormDataContentType()) + +// client := &http.Client{} +// res, err := client.Do(req) +// if err != nil { +// return +// } +// if res.StatusCode != http.StatusOK { +// err = fmt.Errorf("bad status: %s", res.Status) +// } +// return +// } + +func ImportFile(ctx *ImportContext) (err error) { + err = fmt.Errorf("not yet implemented") + return +} diff --git a/src/helsinki.at/rhimport/srvWeb.go b/src/helsinki.at/rhimport/srvWeb.go deleted file mode 100644 index f51c8e8..0000000 --- a/src/helsinki.at/rhimport/srvWeb.go +++ /dev/null @@ -1,41 +0,0 @@ -// -// rhimportd -// -// The Radio Helsinki Rivendell Import Daemon -// -// -// Copyright (C) 2015 Christian Pointner -// -// This file is part of rhimportd. -// -// rhimportd is free software: you can redistribute it and/or modify -// it under the terms of the GNU General Public License as published by -// the Free Software Foundation, either version 3 of the License, or -// any later version. -// -// rhimportd 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 rhimportd. If not, see . -// - -package rhimport - -import ( - "fmt" - "html" - "net/http" - _ "net/http/pprof" -) - -func ServeWeb(addr_s string) { - http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { - fmt.Fprintf(w, "Hello, %q", html.EscapeString(r.URL.Path)) - }) - - rhl.Println("listening on", addr_s) - http.ListenAndServe(addr_s, nil) -} diff --git a/src/helsinki.at/rhimportd/ctrlWeb.go b/src/helsinki.at/rhimportd/ctrlWeb.go new file mode 100644 index 0000000..04180ae --- /dev/null +++ b/src/helsinki.at/rhimportd/ctrlWeb.go @@ -0,0 +1,44 @@ +// +// rhimportd +// +// The Radio Helsinki Rivendell Import Daemon +// +// +// Copyright (C) 2015 Christian Pointner +// +// This file is part of rhimportd. +// +// rhimportd is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// any later version. +// +// rhimportd 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 rhimportd. If not, see . +// + +package main + +import ( + "fmt" + "helsinki.at/rhimport" + "html" + "net/http" + _ "net/http/pprof" +) + +func StartControlWeb(addr_s string) { + http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { + fmt.Fprintf(w, "Hello, %q", html.EscapeString(r.URL.Path)) + ctx := new(rhimport.ImportContext) + rhimport.ImportFile(ctx) + }) + + rhl.Println("listening on", addr_s) + http.ListenAndServe(addr_s, nil) +} diff --git a/src/helsinki.at/rhimportd/log.go b/src/helsinki.at/rhimportd/log.go new file mode 100644 index 0000000..5ff3e6d --- /dev/null +++ b/src/helsinki.at/rhimportd/log.go @@ -0,0 +1,38 @@ +// +// rhimportd +// +// The Radio Helsinki Rivendell Import Daemon +// +// +// Copyright (C) 2015 Christian Pointner +// +// This file is part of rhimportd. +// +// rhimportd is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// any later version. +// +// rhimportd 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 rhimportd. If not, see . +// + +package main + +import ( + "io/ioutil" + "log" + "os" +) + +var ( + rhl = log.New(os.Stderr, "[rhimport]\t", log.LstdFlags) + // use ioutil.Discard to switch that thing off + // rhtl = log.New(os.Stderr, "[rhdbg]\t", log.LstdFlags) + rhtl = log.New(ioutil.Discard, "[rhimport-dbg]\t", log.LstdFlags) +) diff --git a/src/helsinki.at/rhimportd/rhimportd.go b/src/helsinki.at/rhimportd/rhimportd.go index a2bce7b..b73df95 100644 --- a/src/helsinki.at/rhimportd/rhimportd.go +++ b/src/helsinki.at/rhimportd/rhimportd.go @@ -26,15 +26,11 @@ package main import ( "flag" - "helsinki.at/rhimport" - "log" "os" "os/signal" "sync" ) -var rhl = log.New(os.Stderr, "[rhimportd]\t", log.LstdFlags) - func main() { addr_s := flag.String("addr", ":4000", "addr:port to listen on, default: ':4000'") help := flag.Bool("help", false, "show usage") @@ -51,7 +47,7 @@ func main() { go func() { defer wg.Done() rhl.Println("start web-srv") - rhimport.ServeWeb(*addr_s) + StartControlWeb(*addr_s) rhl.Println("web finished") }() -- cgit v0.10.2