2020-12-22 21:15:29 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
2021-06-06 12:39:42 +00:00
|
|
|
func (db *database) shortenPath(p string) (string, error) {
|
2020-12-22 21:15:29 +00:00
|
|
|
if p == "" {
|
|
|
|
return "", errors.New("empty path")
|
|
|
|
}
|
2021-07-03 10:11:57 +00:00
|
|
|
idi, err, _ := db.sp.Do(p, func() (interface{}, error) {
|
|
|
|
id := db.getShortPathID(p)
|
|
|
|
if id == -1 {
|
|
|
|
_, err := db.exec("insert or ignore into shortpath (path) values (@path)", sql.Named("path", p))
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
id = db.getShortPathID(p)
|
2020-12-22 21:15:29 +00:00
|
|
|
}
|
2021-07-03 10:11:57 +00:00
|
|
|
return id, nil
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
2020-12-22 21:15:29 +00:00
|
|
|
}
|
2021-07-03 10:11:57 +00:00
|
|
|
id := idi.(int)
|
2020-12-22 21:15:29 +00:00
|
|
|
if id == -1 {
|
|
|
|
return "", errors.New("failed to retrieve short path for " + p)
|
|
|
|
}
|
|
|
|
return fmt.Sprintf("/s/%x", id), nil
|
|
|
|
}
|
|
|
|
|
2021-06-06 12:39:42 +00:00
|
|
|
func (db *database) getShortPathID(p string) (id int) {
|
2020-12-22 21:15:29 +00:00
|
|
|
if p == "" {
|
|
|
|
return -1
|
|
|
|
}
|
2021-07-03 10:11:57 +00:00
|
|
|
if idi, ok := db.spc.Load(p); ok {
|
|
|
|
return idi.(int)
|
|
|
|
}
|
2021-06-06 12:39:42 +00:00
|
|
|
row, err := db.queryRow("select id from shortpath where path = @path", sql.Named("path", p))
|
2020-12-22 21:15:29 +00:00
|
|
|
if err != nil {
|
|
|
|
return -1
|
|
|
|
}
|
|
|
|
err = row.Scan(&id)
|
|
|
|
if err != nil {
|
|
|
|
return -1
|
|
|
|
}
|
2021-07-03 10:11:57 +00:00
|
|
|
db.spc.Store(p, id)
|
2020-12-22 21:15:29 +00:00
|
|
|
return id
|
|
|
|
}
|