miniflux/storage/integration.go

407 lines
11 KiB
Go
Raw Normal View History

2017-12-03 04:32:14 +01: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.
2018-08-25 06:51:50 +02:00
package storage // import "miniflux.app/storage"
2017-12-03 04:32:14 +01:00
import (
"database/sql"
"fmt"
"golang.org/x/crypto/bcrypt"
2018-08-25 06:51:50 +02:00
"miniflux.app/model"
2017-12-03 04:32:14 +01:00
)
2022-01-03 05:12:29 +01:00
// HasDuplicateFeverUsername checks if another user have the same Fever username.
func (s *Storage) HasDuplicateFeverUsername(userID int64, feverUsername string) bool {
2019-10-30 06:48:07 +01:00
query := `SELECT true FROM integrations WHERE user_id != $1 AND fever_username=$2`
var result bool
s.db.QueryRow(query, userID, feverUsername).Scan(&result)
2019-10-30 06:48:07 +01:00
return result
}
2022-01-03 05:12:29 +01:00
// HasDuplicateGoogleReaderUsername checks if another user have the same Google Reader username.
func (s *Storage) HasDuplicateGoogleReaderUsername(userID int64, googleReaderUsername string) bool {
query := `SELECT true FROM integrations WHERE user_id != $1 AND googlereader_username=$2`
var result bool
s.db.QueryRow(query, userID, googleReaderUsername).Scan(&result)
return result
}
2017-12-04 02:44:27 +01:00
// UserByFeverToken returns a user by using the Fever API token.
func (s *Storage) UserByFeverToken(token string) (*model.User, error) {
query := `
SELECT
users.id, users.is_admin, users.timezone
2022-01-03 05:12:29 +01:00
FROM
users
LEFT JOIN
integrations ON integrations.user_id=users.id
2019-10-30 06:48:07 +01:00
WHERE
integrations.fever_enabled='t' AND lower(integrations.fever_token)=lower($1)
2017-12-04 02:44:27 +01:00
`
var user model.User
err := s.db.QueryRow(query, token).Scan(&user.ID, &user.IsAdmin, &user.Timezone)
switch {
case err == sql.ErrNoRows:
return nil, nil
case err != nil:
2022-01-03 05:12:29 +01:00
return nil, fmt.Errorf("store: unable to fetch user: %v", err)
2019-10-30 06:48:07 +01:00
default:
return &user, nil
2017-12-04 02:44:27 +01:00
}
}
2022-01-03 05:12:29 +01:00
// GoogleReaderUserCheckPassword validates the Google Reader hashed password.
func (s *Storage) GoogleReaderUserCheckPassword(username, password string) error {
var hash string
query := `
SELECT
googlereader_password
2022-01-03 05:12:29 +01:00
FROM
integrations
WHERE
integrations.googlereader_enabled='t' AND integrations.googlereader_username=$1
`
err := s.db.QueryRow(query, username).Scan(&hash)
if err == sql.ErrNoRows {
return fmt.Errorf(`store: unable to find this user: %s`, username)
} else if err != nil {
return fmt.Errorf(`store: unable to fetch user: %v`, err)
}
if err := bcrypt.CompareHashAndPassword([]byte(hash), []byte(password)); err != nil {
return fmt.Errorf(`store: invalid password for "%s" (%v)`, username, err)
}
return nil
}
2022-01-03 05:12:29 +01:00
// GoogleReaderUserGetIntegration returns part of the Google Reader parts of the integration struct.
func (s *Storage) GoogleReaderUserGetIntegration(username string) (*model.Integration, error) {
var integration model.Integration
query := `
SELECT
user_id,
googlereader_enabled,
googlereader_username,
googlereader_password
2022-01-03 05:12:29 +01:00
FROM
integrations
WHERE
integrations.googlereader_enabled='t' AND integrations.googlereader_username=$1
`
err := s.db.QueryRow(query, username).Scan(&integration.UserID, &integration.GoogleReaderEnabled, &integration.GoogleReaderUsername, &integration.GoogleReaderPassword)
if err == sql.ErrNoRows {
return &integration, fmt.Errorf(`store: unable to find this user: %s`, username)
} else if err != nil {
return &integration, fmt.Errorf(`store: unable to fetch user: %v`, err)
}
return &integration, nil
}
2017-12-03 04:32:14 +01:00
// Integration returns user integration settings.
func (s *Storage) Integration(userID int64) (*model.Integration, error) {
2019-10-30 06:48:07 +01:00
query := `
SELECT
2017-12-03 04:32:14 +01:00
user_id,
pinboard_enabled,
pinboard_token,
pinboard_tags,
2017-12-03 06:12:03 +01:00
pinboard_mark_as_unread,
instapaper_enabled,
instapaper_username,
2017-12-04 02:44:27 +01:00
instapaper_password,
fever_enabled,
fever_username,
2017-12-19 05:52:46 +01:00
fever_token,
googlereader_enabled,
googlereader_username,
googlereader_password,
2017-12-19 05:52:46 +01:00
wallabag_enabled,
wallabag_only_url,
2017-12-19 05:52:46 +01:00
wallabag_url,
wallabag_client_id,
wallabag_client_secret,
wallabag_username,
2018-02-25 20:49:08 +01:00
wallabag_password,
nunux_keeper_enabled,
nunux_keeper_url,
2018-05-20 22:31:56 +02:00
nunux_keeper_api_key,
2022-04-21 04:44:47 +02:00
espial_enabled,
espial_url,
espial_api_key,
espial_tags,
2018-05-20 22:31:56 +02:00
pocket_enabled,
pocket_access_token,
2021-09-08 05:04:22 +02:00
pocket_consumer_key,
telegram_bot_enabled,
telegram_bot_token,
2022-05-23 17:53:06 +02:00
telegram_bot_chat_id,
linkding_enabled,
linkding_url,
linkding_api_key
2019-10-30 06:48:07 +01:00
FROM
integrations
WHERE
user_id=$1
2017-12-03 04:32:14 +01:00
`
var integration model.Integration
err := s.db.QueryRow(query, userID).Scan(
&integration.UserID,
&integration.PinboardEnabled,
&integration.PinboardToken,
&integration.PinboardTags,
&integration.PinboardMarkAsUnread,
2017-12-03 06:12:03 +01:00
&integration.InstapaperEnabled,
&integration.InstapaperUsername,
&integration.InstapaperPassword,
2017-12-04 02:44:27 +01:00
&integration.FeverEnabled,
&integration.FeverUsername,
&integration.FeverToken,
&integration.GoogleReaderEnabled,
&integration.GoogleReaderUsername,
&integration.GoogleReaderPassword,
2017-12-19 05:52:46 +01:00
&integration.WallabagEnabled,
&integration.WallabagOnlyURL,
2017-12-19 05:52:46 +01:00
&integration.WallabagURL,
&integration.WallabagClientID,
&integration.WallabagClientSecret,
&integration.WallabagUsername,
&integration.WallabagPassword,
2018-02-25 20:49:08 +01:00
&integration.NunuxKeeperEnabled,
&integration.NunuxKeeperURL,
&integration.NunuxKeeperAPIKey,
2022-04-21 04:44:47 +02:00
&integration.EspialEnabled,
&integration.EspialURL,
&integration.EspialAPIKey,
&integration.EspialTags,
2018-05-20 22:31:56 +02:00
&integration.PocketEnabled,
&integration.PocketAccessToken,
&integration.PocketConsumerKey,
2021-09-08 05:04:22 +02:00
&integration.TelegramBotEnabled,
&integration.TelegramBotToken,
&integration.TelegramBotChatID,
2022-05-23 17:53:06 +02:00
&integration.LinkdingEnabled,
&integration.LinkdingURL,
&integration.LinkdingAPIKey,
2017-12-03 04:32:14 +01:00
)
switch {
case err == sql.ErrNoRows:
2017-12-16 03:55:57 +01:00
return &integration, nil
2017-12-03 04:32:14 +01:00
case err != nil:
2019-10-30 06:48:07 +01:00
return &integration, fmt.Errorf(`store: unable to fetch integration row: %v`, err)
default:
return &integration, nil
2017-12-03 04:32:14 +01:00
}
}
// UpdateIntegration saves user integration settings.
func (s *Storage) UpdateIntegration(integration *model.Integration) error {
var err error
if integration.GoogleReaderPassword != "" {
integration.GoogleReaderPassword, err = hashPassword(integration.GoogleReaderPassword)
if err != nil {
return err
}
query := `
2019-10-30 06:48:07 +01:00
UPDATE
integrations
SET
2017-12-03 04:32:14 +01:00
pinboard_enabled=$1,
pinboard_token=$2,
pinboard_tags=$3,
2017-12-03 06:12:03 +01:00
pinboard_mark_as_unread=$4,
instapaper_enabled=$5,
instapaper_username=$6,
2017-12-04 02:44:27 +01:00
instapaper_password=$7,
fever_enabled=$8,
fever_username=$9,
fever_token=$10,
wallabag_enabled=$11,
wallabag_only_url=$12,
wallabag_url=$13,
wallabag_client_id=$14,
wallabag_client_secret=$15,
wallabag_username=$16,
wallabag_password=$17,
nunux_keeper_enabled=$18,
nunux_keeper_url=$19,
nunux_keeper_api_key=$20,
pocket_enabled=$21,
pocket_access_token=$22,
pocket_consumer_key=$23,
googlereader_enabled=$24,
googlereader_username=$25,
googlereader_password=$26,
telegram_bot_enabled=$27,
telegram_bot_token=$28,
telegram_bot_chat_id=$29,
espial_enabled=$30,
espial_url=$31,
espial_api_key=$32,
espial_tags=$33,
linkding_enabled=$34,
linkding_url=$35,
linkding_api_key=$36
2019-10-30 06:48:07 +01:00
WHERE
user_id=$37
2017-12-03 04:32:14 +01:00
`
_, err = s.db.Exec(
query,
integration.PinboardEnabled,
integration.PinboardToken,
integration.PinboardTags,
integration.PinboardMarkAsUnread,
integration.InstapaperEnabled,
integration.InstapaperUsername,
integration.InstapaperPassword,
integration.FeverEnabled,
integration.FeverUsername,
integration.FeverToken,
integration.WallabagEnabled,
integration.WallabagOnlyURL,
integration.WallabagURL,
integration.WallabagClientID,
integration.WallabagClientSecret,
integration.WallabagUsername,
integration.WallabagPassword,
integration.NunuxKeeperEnabled,
integration.NunuxKeeperURL,
integration.NunuxKeeperAPIKey,
integration.PocketEnabled,
integration.PocketAccessToken,
integration.PocketConsumerKey,
integration.GoogleReaderEnabled,
integration.GoogleReaderUsername,
integration.GoogleReaderPassword,
integration.TelegramBotEnabled,
integration.TelegramBotToken,
integration.TelegramBotChatID,
2022-04-21 04:44:47 +02:00
integration.EspialEnabled,
integration.EspialURL,
integration.EspialAPIKey,
integration.EspialTags,
2022-05-23 17:53:06 +02:00
integration.LinkdingEnabled,
integration.LinkdingURL,
integration.LinkdingAPIKey,
integration.UserID,
)
} else {
query := `
UPDATE
integrations
SET
pinboard_enabled=$1,
pinboard_token=$2,
pinboard_tags=$3,
pinboard_mark_as_unread=$4,
instapaper_enabled=$5,
instapaper_username=$6,
instapaper_password=$7,
fever_enabled=$8,
fever_username=$9,
fever_token=$10,
wallabag_enabled=$11,
wallabag_only_url=$12,
wallabag_url=$13,
wallabag_client_id=$14,
wallabag_client_secret=$15,
wallabag_username=$16,
wallabag_password=$17,
nunux_keeper_enabled=$18,
nunux_keeper_url=$19,
nunux_keeper_api_key=$20,
pocket_enabled=$21,
pocket_access_token=$22,
pocket_consumer_key=$23,
googlereader_enabled=$24,
googlereader_username=$25,
googlereader_password=$26,
telegram_bot_enabled=$27,
telegram_bot_token=$28,
telegram_bot_chat_id=$29,
espial_enabled=$30,
espial_url=$31,
espial_api_key=$32,
espial_tags=$33,
linkding_enabled=$34,
linkding_url=$35,
linkding_api_key=$36
WHERE
user_id=$37
`
_, err = s.db.Exec(
query,
integration.PinboardEnabled,
integration.PinboardToken,
integration.PinboardTags,
integration.PinboardMarkAsUnread,
integration.InstapaperEnabled,
integration.InstapaperUsername,
integration.InstapaperPassword,
integration.FeverEnabled,
integration.FeverUsername,
integration.FeverToken,
integration.WallabagEnabled,
integration.WallabagOnlyURL,
integration.WallabagURL,
integration.WallabagClientID,
integration.WallabagClientSecret,
integration.WallabagUsername,
integration.WallabagPassword,
integration.NunuxKeeperEnabled,
integration.NunuxKeeperURL,
integration.NunuxKeeperAPIKey,
integration.PocketEnabled,
integration.PocketAccessToken,
integration.PocketConsumerKey,
integration.GoogleReaderEnabled,
integration.GoogleReaderUsername,
integration.GoogleReaderPassword,
integration.TelegramBotEnabled,
integration.TelegramBotToken,
integration.TelegramBotChatID,
2022-04-21 04:44:47 +02:00
integration.EspialEnabled,
integration.EspialURL,
integration.EspialAPIKey,
integration.EspialTags,
2022-05-23 17:53:06 +02:00
integration.LinkdingEnabled,
integration.LinkdingURL,
integration.LinkdingAPIKey,
integration.UserID,
)
}
2017-12-03 04:32:14 +01:00
if err != nil {
2019-10-30 06:48:07 +01:00
return fmt.Errorf(`store: unable to update integration row: %v`, err)
2017-12-03 04:32:14 +01:00
}
return nil
}
// HasSaveEntry returns true if the given user can save articles to third-parties.
func (s *Storage) HasSaveEntry(userID int64) (result bool) {
query := `
2019-10-30 06:48:07 +01:00
SELECT
true
FROM
integrations
WHERE
user_id=$1
AND
2022-05-23 17:53:06 +02:00
(pinboard_enabled='t' OR instapaper_enabled='t' OR wallabag_enabled='t' OR nunux_keeper_enabled='t' OR espial_enabled='t' OR pocket_enabled='t' OR linkding_enabled='t')
`
if err := s.db.QueryRow(query, userID).Scan(&result); err != nil {
result = false
}
return result
}