Compare commits
No commits in common. '612c6ebde56d7ce62b44f735e9425acf681a927f' and '82f252f32fe74654fec5476562df3d95925395eb' have entirely different histories.
612c6ebde5
...
82f252f32f
File diff suppressed because it is too large
Load Diff
@ -1,125 +0,0 @@
|
|||||||
package diyanetcitydb
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"database/sql"
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/doug-martin/goqu/v9"
|
|
||||||
|
|
||||||
"prayertimes/pkg/prayer"
|
|
||||||
)
|
|
||||||
|
|
||||||
var ErrLocationNotFound = errors.New("location not found")
|
|
||||||
|
|
||||||
type Provider struct {
|
|
||||||
db *goqu.Database
|
|
||||||
}
|
|
||||||
|
|
||||||
func New(conn *sql.DB) Provider {
|
|
||||||
return Provider{db: goqu.New("sqlite3", conn)}
|
|
||||||
}
|
|
||||||
|
|
||||||
type locationRow struct {
|
|
||||||
ID int `db:"id"`
|
|
||||||
Country string `db:"country"`
|
|
||||||
City string `db:"city"`
|
|
||||||
Region string `db:"region"`
|
|
||||||
Latitude float64 `db:"latitude"`
|
|
||||||
Longitude float64 `db:"longitude"`
|
|
||||||
Timezone string `db:"timezone"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p Provider) SearchLocations(ctx context.Context, query string) ([]prayer.LegacyLocation, error) {
|
|
||||||
query = strings.TrimSpace(query)
|
|
||||||
if query == "" {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
pattern := "%" + query + "%"
|
|
||||||
|
|
||||||
q := p.db.
|
|
||||||
From("diyanet_cities").
|
|
||||||
Select(
|
|
||||||
goqu.I("id"),
|
|
||||||
goqu.I("country"),
|
|
||||||
goqu.I("city"),
|
|
||||||
goqu.COALESCE(goqu.I("region"), "").As("region"),
|
|
||||||
goqu.I("latitude"),
|
|
||||||
goqu.I("longitude"),
|
|
||||||
goqu.COALESCE(goqu.I("timezone"), "").As("timezone"),
|
|
||||||
).
|
|
||||||
Where(
|
|
||||||
goqu.Or(
|
|
||||||
goqu.L("country LIKE ? COLLATE NOCASE", pattern),
|
|
||||||
goqu.L("city LIKE ? COLLATE NOCASE", pattern),
|
|
||||||
goqu.L("COALESCE(region, '') LIKE ? COLLATE NOCASE", pattern),
|
|
||||||
),
|
|
||||||
).
|
|
||||||
Order(
|
|
||||||
goqu.I("country").Asc(),
|
|
||||||
goqu.I("city").Asc(),
|
|
||||||
goqu.I("region").Asc(),
|
|
||||||
goqu.I("id").Asc(),
|
|
||||||
).
|
|
||||||
Limit(100)
|
|
||||||
|
|
||||||
rows := make([]locationRow, 0)
|
|
||||||
if err := q.ScanStructsContext(ctx, &rows); err != nil {
|
|
||||||
return nil, fmt.Errorf("failed to query diyanet locations: %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
locations := make([]prayer.LegacyLocation, 0, len(rows))
|
|
||||||
for _, row := range rows {
|
|
||||||
locations = append(locations, prayer.LegacyLocation{
|
|
||||||
ID: row.ID,
|
|
||||||
Country: row.Country,
|
|
||||||
City: row.City,
|
|
||||||
Region: row.Region,
|
|
||||||
Latitude: row.Latitude,
|
|
||||||
Longitude: row.Longitude,
|
|
||||||
Timezone: row.Timezone,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
return locations, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p Provider) GetLocationByID(ctx context.Context, id int) (prayer.LegacyLocation, error) {
|
|
||||||
q := p.db.
|
|
||||||
From("diyanet_cities").
|
|
||||||
Select(
|
|
||||||
goqu.I("id"),
|
|
||||||
goqu.I("country"),
|
|
||||||
goqu.I("city"),
|
|
||||||
goqu.COALESCE(goqu.I("region"), "").As("region"),
|
|
||||||
goqu.I("latitude"),
|
|
||||||
goqu.I("longitude"),
|
|
||||||
goqu.COALESCE(goqu.I("timezone"), "").As("timezone"),
|
|
||||||
).
|
|
||||||
Where(goqu.I("id").Eq(id)).
|
|
||||||
Limit(1)
|
|
||||||
|
|
||||||
var rows []locationRow
|
|
||||||
if err := q.ScanStructsContext(ctx, &rows); err != nil {
|
|
||||||
return prayer.LegacyLocation{}, fmt.Errorf("failed to query location by id: %w", err)
|
|
||||||
}
|
|
||||||
if len(rows) == 0 {
|
|
||||||
return prayer.LegacyLocation{}, ErrLocationNotFound
|
|
||||||
}
|
|
||||||
|
|
||||||
row := rows[0]
|
|
||||||
location := prayer.LegacyLocation{
|
|
||||||
ID: row.ID,
|
|
||||||
Country: row.Country,
|
|
||||||
City: row.City,
|
|
||||||
Region: row.Region,
|
|
||||||
Latitude: row.Latitude,
|
|
||||||
Longitude: row.Longitude,
|
|
||||||
Timezone: row.Timezone,
|
|
||||||
}
|
|
||||||
|
|
||||||
return location, nil
|
|
||||||
}
|
|
||||||
Loading…
Reference in New Issue