| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | 
							- // Copyright (C) 2025 The Syncthing Authors.
 
- //
 
- // This Source Code Form is subject to the terms of the Mozilla Public
 
- // License, v. 2.0. If a copy of the MPL was not distributed with this file,
 
- // You can obtain one at https://mozilla.org/MPL/2.0/.
 
- package sqlite
 
- import (
 
- 	"iter"
 
- 	"github.com/jmoiron/sqlx"
 
- 	"github.com/syncthing/syncthing/internal/db"
 
- )
 
- func (s *baseDB) GetKV(key string) ([]byte, error) {
 
- 	var val []byte
 
- 	if err := s.stmt(`
 
- 		SELECT value FROM kv
 
- 		WHERE key = ?
 
- 	`).Get(&val, key); err != nil {
 
- 		return nil, wrap(err)
 
- 	}
 
- 	return val, nil
 
- }
 
- func (s *baseDB) PutKV(key string, val []byte) error {
 
- 	s.updateLock.Lock()
 
- 	defer s.updateLock.Unlock()
 
- 	_, err := s.stmt(`
 
- 		INSERT OR REPLACE INTO kv (key, value)
 
- 		VALUES (?, ?)
 
- 	`).Exec(key, val)
 
- 	return wrap(err)
 
- }
 
- func (s *baseDB) DeleteKV(key string) error {
 
- 	s.updateLock.Lock()
 
- 	defer s.updateLock.Unlock()
 
- 	_, err := s.stmt(`
 
- 		DELETE FROM kv WHERE key = ?
 
- 	`).Exec(key)
 
- 	return wrap(err)
 
- }
 
- func (s *baseDB) PrefixKV(prefix string) (iter.Seq[db.KeyValue], func() error) {
 
- 	var rows *sqlx.Rows
 
- 	var err error
 
- 	if prefix == "" {
 
- 		rows, err = s.stmt(`SELECT key, value FROM kv`).Queryx()
 
- 	} else {
 
- 		end := prefixEnd(prefix)
 
- 		rows, err = s.stmt(`
 
- 			SELECT key, value FROM kv
 
- 			WHERE key >= ? AND key < ?
 
- 		`).Queryx(prefix, end)
 
- 	}
 
- 	if err != nil {
 
- 		return func(_ func(db.KeyValue) bool) {}, func() error { return err }
 
- 	}
 
- 	return func(yield func(db.KeyValue) bool) {
 
- 			defer rows.Close()
 
- 			for rows.Next() {
 
- 				var key string
 
- 				var val []byte
 
- 				if err = rows.Scan(&key, &val); err != nil {
 
- 					return
 
- 				}
 
- 				if !yield(db.KeyValue{Key: key, Value: val}) {
 
- 					return
 
- 				}
 
- 			}
 
- 			err = rows.Err()
 
- 		}, func() error {
 
- 			return err
 
- 		}
 
- }
 
 
  |