kyoketsu-web.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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. "fmt"
  24. "log"
  25. "os"
  26. "sync"
  27. kyoketsu "git.aetherial.dev/aeth/kyoketsu/pkg"
  28. )
  29. const dbfile = "sqlite.db"
  30. func main() {
  31. os.Remove(dbfile) // TODO: remove this once i add more smart interaction with the DB
  32. db, err := sql.Open("sqlite3", dbfile)
  33. if err != nil {
  34. log.Fatal(err)
  35. }
  36. hostsRepo := kyoketsu.NewSQLiteRepo(db)
  37. var wg sync.WaitGroup
  38. wg.Add(1)
  39. go kyoketsu.RunHttpServer(8082, hostsRepo)
  40. if err = hostsRepo.Migrate(); err != nil {
  41. log.Fatal(err)
  42. }
  43. log.Println("SUCCESS ::: SQLite database initiated, and open for writing.")
  44. hosts, err := kyoketsu.NetSweep(os.Args[1], kyoketsu.RetrieveScanDirectives().Pairs)
  45. if err != nil {
  46. log.Fatal(err)
  47. }
  48. for i := range hosts {
  49. fmt.Printf("%+v\n", hosts[i])
  50. _, err := hostsRepo.Create(*hosts[i])
  51. if err != nil {
  52. log.Fatalf("Couldnt create new entry :( error: %s\n", err)
  53. }
  54. }
  55. wg.Wait()
  56. }