kyoketsu-web.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /*
  2. GNU GENERAL PUBLIC LICENSE
  3. Version 3, 29 June 2007
  4. kyoketsu, a Client-To-Client Network Enumeration System
  5. Copyright (C) 2024 Russell Hrubesky, ChiralWorks Software LLC
  6. Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
  7. Everyone is permitted to copy and distribute verbatim copies
  8. of this license document, but changing it is not allowed.
  9. This program is free software: you can redistribute it and/or modify
  10. it under the terms of the GNU General Public License as published by
  11. the Free Software Foundation, either version 3 of the License,
  12. or (at your option) any later version.
  13. This program is distributed in the hope that it will be useful,
  14. but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  16. See the GNU General Public License for more details.
  17. You should have received a copy of the GNU General Public License
  18. along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. */
  20. package main
  21. import (
  22. "database/sql"
  23. "flag"
  24. "log"
  25. "net/http"
  26. "os"
  27. "sync"
  28. kyoketsu "git.aetherial.dev/aeth/kyoketsu/pkg"
  29. )
  30. const dbfile = "sqlite.db"
  31. func main() {
  32. port := flag.Int("port", 8080, "Select the port to run the server on")
  33. debug := flag.Bool("debug", false, "Pass this to start the pprof server")
  34. flag.Parse()
  35. db, err := sql.Open("sqlite3", dbfile)
  36. if err != nil {
  37. log.Fatal(err)
  38. }
  39. if *debug {
  40. go func() {
  41. log.Println(http.ListenAndServe("localhost:6060", nil))
  42. }()
  43. }
  44. hostsRepo := kyoketsu.NewSQLiteRepo(db)
  45. var wg sync.WaitGroup
  46. wg.Add(1)
  47. go kyoketsu.RunHttpServer(*port, hostsRepo, kyoketsu.RetrieveScanDirectives(), os.Stdout)
  48. if err = hostsRepo.Migrate(); err != nil {
  49. log.Fatal(err)
  50. }
  51. log.Println("SUCCESS ::: SQLite database initiated, and open for writing.")
  52. wg.Wait()
  53. }