blob: adc7a80a9144897ffd6cddb474b20af5141f5ab7 [file] [log] [blame]
// Copyright 2019 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package postgres
import (
"context"
"database/sql"
"github.com/lib/pq"
"golang.org/x/pkgsite/internal/database"
"golang.org/x/pkgsite/internal/derrors"
)
// DeletePseudoversionsExcept deletes all pseudoversions for the module except
// the provided resolvedVersion.
func (db *DB) DeletePseudoversionsExcept(ctx context.Context, modulePath, resolvedVersion string) (err error) {
defer derrors.WrapStack(&err, "DeletePseudoversionsExcept(ctx, db, %q, %q)", modulePath, resolvedVersion)
return db.db.Transact(ctx, sql.LevelDefault, func(tx *database.DB) error {
var versions []string
collect := func(rows *sql.Rows) error {
var version string
if err := rows.Scan(&version); err != nil {
return err
}
versions = append(versions, version)
return nil
}
const stmt = `
DELETE FROM modules
WHERE version_type = 'pseudo' AND module_path=$1 AND version != $2
RETURNING version`
if err := tx.RunQuery(ctx, stmt, collect, modulePath, resolvedVersion); err != nil {
return err
}
_, err := tx.Exec(ctx, `DELETE FROM version_map WHERE module_path = $1 AND resolved_version = ANY($2)`,
modulePath, pq.Array(versions))
return err
})
}