Restrucuture
This commit is contained in:
15
app/handlers/api/00_api.go
Normal file
15
app/handlers/api/00_api.go
Normal file
@@ -0,0 +1,15 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
)
|
||||
|
||||
// Global Variables
|
||||
var DB *sql.DB
|
||||
|
||||
// check error
|
||||
func check(err error) {
|
||||
if err != nil {
|
||||
panic(err.Error())
|
||||
}
|
||||
}
|
||||
47
app/handlers/api/10_getJSON.go
Normal file
47
app/handlers/api/10_getJSON.go
Normal file
@@ -0,0 +1,47 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
|
||||
"gitea.voser.cloud/Golang/GoDown/handlers/sqldb"
|
||||
)
|
||||
|
||||
func getJSON(sqlString string) ([]byte, error) {
|
||||
DB = sqldb.Opendb()
|
||||
defer DB.Close()
|
||||
rows, err := DB.Query(sqlString)
|
||||
check(err)
|
||||
defer rows.Close()
|
||||
columns, err := rows.Columns()
|
||||
if err != nil {
|
||||
return []byte("Error while generating json"), err
|
||||
}
|
||||
count := len(columns)
|
||||
tableData := make([]map[string]interface{}, 0)
|
||||
values := make([]interface{}, count)
|
||||
valuePtrs := make([]interface{}, count)
|
||||
for rows.Next() {
|
||||
for i := 0; i < count; i++ {
|
||||
valuePtrs[i] = &values[i]
|
||||
}
|
||||
rows.Scan(valuePtrs...)
|
||||
entry := make(map[string]interface{})
|
||||
for i, col := range columns {
|
||||
var v interface{}
|
||||
val := values[i]
|
||||
b, ok := val.([]byte)
|
||||
if ok {
|
||||
v = string(b)
|
||||
} else {
|
||||
v = val
|
||||
}
|
||||
entry[col] = v
|
||||
}
|
||||
tableData = append(tableData, entry)
|
||||
}
|
||||
jsonData, err := json.Marshal(tableData)
|
||||
if err != nil {
|
||||
return []byte("Error while generating json"), err
|
||||
}
|
||||
return jsonData, nil
|
||||
}
|
||||
30
app/handlers/api/10_ytid_in_db.go
Normal file
30
app/handlers/api/10_ytid_in_db.go
Normal file
@@ -0,0 +1,30 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"gitea.voser.cloud/Golang/GoDown/handlers/sqldb"
|
||||
"gitea.voser.cloud/Golang/GoDown/handlers/ytdl"
|
||||
)
|
||||
|
||||
func ytid_in_db(ytid string) string {
|
||||
DB = sqldb.Opendb()
|
||||
defer DB.Close()
|
||||
sqlString := fmt.Sprintf("SELECT COUNT(ytid) FROM testdb.media WHERE ytid LIKE \"%v\";", ytid)
|
||||
var count int
|
||||
err := DB.QueryRow(sqlString).Scan(&count)
|
||||
check(err)
|
||||
if count == 0 {
|
||||
fmt.Printf("Start download of: %s \n", ytid)
|
||||
ytdl.DlAudio(ytid)
|
||||
fmt.Printf("Adding to database: %s \n", ytid)
|
||||
ytdl.AddMedia(ytid)
|
||||
fmt.Printf("Finished download of: %s \n", ytid)
|
||||
return "Song is now available"
|
||||
}
|
||||
if count == 1 {
|
||||
return "Song was already available"
|
||||
}
|
||||
error_return := fmt.Sprintf("Rows returned: %d --> there is an Issue within the database", count)
|
||||
return error_return
|
||||
}
|
||||
17
app/handlers/api/20_GET_api_add_ytid.go
Normal file
17
app/handlers/api/20_GET_api_add_ytid.go
Normal file
@@ -0,0 +1,17 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"net/url"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
func GET_api_add_ytid(c *gin.Context) {
|
||||
newSong_ytid := c.Param("ytid")
|
||||
newSong_url := "https://www.youtube.com/watch?v=" + newSong_ytid
|
||||
_, err := url.ParseRequestURI(newSong_url)
|
||||
check(err)
|
||||
is_available := ytid_in_db(newSong_ytid)
|
||||
c.String(http.StatusOK, is_available)
|
||||
}
|
||||
14
app/handlers/api/20_GET_api_db.go
Normal file
14
app/handlers/api/20_GET_api_db.go
Normal file
@@ -0,0 +1,14 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
func GET_api_db(c *gin.Context) {
|
||||
dbquery := "SELECT * FROM testdb.media"
|
||||
media, err := getJSON(dbquery)
|
||||
check(err)
|
||||
c.Data(http.StatusOK, "application/json", media)
|
||||
}
|
||||
16
app/handlers/api/20_GET_api_get_ytid.go
Normal file
16
app/handlers/api/20_GET_api_get_ytid.go
Normal file
@@ -0,0 +1,16 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
func GET_api_get_ytid(c *gin.Context) {
|
||||
ytid := c.Param("ytid")
|
||||
sqlString := fmt.Sprintf("SELECT * FROM testdb.media WHERE ytid LIKE \"%v\";", ytid)
|
||||
json, err := getJSON(sqlString)
|
||||
check(err)
|
||||
c.Data(http.StatusOK, "application/json", json)
|
||||
}
|
||||
@@ -1,101 +0,0 @@
|
||||
package api
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"net/http"
|
||||
"net/url"
|
||||
|
||||
"gitea.voser.cloud/Golang/GoDown/handlers/sqldb"
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
// Global Variables
|
||||
var DB *sql.DB
|
||||
|
||||
// check error
|
||||
func check(err error) {
|
||||
if err != nil {
|
||||
panic(err.Error())
|
||||
}
|
||||
}
|
||||
|
||||
func GET_api_db(c *gin.Context) {
|
||||
dbquery := fmt.Sprintf("SELECT * FROM testdb.media")
|
||||
media, err := getJSON(dbquery)
|
||||
check(err)
|
||||
c.Data(http.StatusOK, "application/json", media)
|
||||
}
|
||||
|
||||
func GET_api_add_ytid(c *gin.Context) {
|
||||
newSong_ytid := c.Param("ytid")
|
||||
newSong_url := "https://www.youtube.com/watch?v=" + newSong_ytid
|
||||
_, err := url.ParseRequestURI(newSong_url)
|
||||
check(err)
|
||||
is_available := ytid_in_db(newSong_ytid)
|
||||
c.String(http.StatusOK, is_available)
|
||||
}
|
||||
|
||||
func ytid_in_db(ytid string) string {
|
||||
sqlString := fmt.Sprintf("SELECT COUNT(ytid) FROM testdb.media WHERE ytid LIKE \"%v\";", ytid)
|
||||
var count int
|
||||
err := DB.QueryRow(sqlString).Scan(&count)
|
||||
check(err)
|
||||
if count == 0 {
|
||||
return "Song is not available"
|
||||
}
|
||||
if count == 1 {
|
||||
return "Song is available"
|
||||
}
|
||||
error_return := fmt.Sprintf("Rows returned: %s --> there is an Issue within the database", string(count))
|
||||
return error_return
|
||||
}
|
||||
|
||||
func GET_api_get_ytid(c *gin.Context) {
|
||||
ytid := c.Param("ytid")
|
||||
sqlString := fmt.Sprintf("SELECT * FROM testdb.media WHERE ytid LIKE \"%v\";", ytid)
|
||||
json, err := getJSON(sqlString)
|
||||
check(err)
|
||||
c.Data(http.StatusOK, "application/json", json)
|
||||
}
|
||||
|
||||
func getJSON(sqlString string) ([]byte, error) {
|
||||
DB = sqldb.Opendb()
|
||||
defer DB.Close()
|
||||
rows, err := DB.Query(sqlString)
|
||||
check(err)
|
||||
defer rows.Close()
|
||||
columns, err := rows.Columns()
|
||||
if err != nil {
|
||||
return []byte("Error while generating json"), err
|
||||
}
|
||||
count := len(columns)
|
||||
tableData := make([]map[string]interface{}, 0)
|
||||
values := make([]interface{}, count)
|
||||
valuePtrs := make([]interface{}, count)
|
||||
for rows.Next() {
|
||||
for i := 0; i < count; i++ {
|
||||
valuePtrs[i] = &values[i]
|
||||
}
|
||||
rows.Scan(valuePtrs...)
|
||||
entry := make(map[string]interface{})
|
||||
for i, col := range columns {
|
||||
var v interface{}
|
||||
val := values[i]
|
||||
b, ok := val.([]byte)
|
||||
if ok {
|
||||
v = string(b)
|
||||
} else {
|
||||
v = val
|
||||
}
|
||||
entry[col] = v
|
||||
}
|
||||
tableData = append(tableData, entry)
|
||||
}
|
||||
jsonData, err := json.Marshal(tableData)
|
||||
if err != nil {
|
||||
return []byte("Error while generating json"), err
|
||||
}
|
||||
return jsonData, nil
|
||||
}
|
||||
Reference in New Issue
Block a user