2017-11-20 00:10:04 -05:00
|
|
|
// Copyright 2017 Frédéric Guillot. All rights reserved.
|
|
|
|
// Use of this source code is governed by the Apache 2.0
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package storage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
2017-11-28 00:30:04 -05:00
|
|
|
|
2018-01-02 22:15:08 -05:00
|
|
|
"github.com/miniflux/miniflux/timer"
|
2017-11-20 00:10:04 -05:00
|
|
|
)
|
|
|
|
|
2017-11-28 00:30:04 -05:00
|
|
|
// Timezones returns all timezones supported by the database.
|
|
|
|
func (s *Storage) Timezones() (map[string]string, error) {
|
2018-01-02 22:15:08 -05:00
|
|
|
defer timer.ExecutionTime(time.Now(), "[Storage:Timezones]")
|
2017-11-20 00:10:04 -05:00
|
|
|
|
|
|
|
timezones := make(map[string]string)
|
|
|
|
query := `select name from pg_timezone_names() order by name asc`
|
|
|
|
rows, err := s.db.Query(query)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("unable to fetch timezones: %v", err)
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
for rows.Next() {
|
|
|
|
var timezone string
|
|
|
|
if err := rows.Scan(&timezone); err != nil {
|
|
|
|
return nil, fmt.Errorf("unable to fetch timezones row: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
timezones[timezone] = timezone
|
|
|
|
}
|
|
|
|
|
|
|
|
return timezones, nil
|
|
|
|
}
|