mirror of
https://github.com/matrix-org/dendrite
synced 2024-11-16 23:00:53 +01:00
51ab0a8ccf
This is #2819 but rebased on latest `main`. This PR is against main too as opposed to the `moderncsqlite` branch. The main change here is simply: ```go // add query parameters to the dsn if strings.Contains(dsn, "?") { dsn += "&" } else { dsn += "?" } // wait some time before erroring if the db is locked // https://gitlab.com/cznic/sqlite/-/issues/106#note_1058094993 dsn += "_pragma=busy_timeout%3d10000" ``` ### Pull Request Checklist <!-- Please read https://matrix-org.github.io/dendrite/development/contributing before submitting your pull request --> * [x] I have added tests for PR _or_ I have justified why this PR doesn't need tests. * [x] Pull request includes a [sign off below using a legally identifiable name](https://matrix-org.github.io/dendrite/development/contributing#sign-off) _or_ I have already signed off privately Signed off privately. Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
36 lines
1.1 KiB
Go
36 lines
1.1 KiB
Go
// Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
//go:build !wasm && cgo
|
|
// +build !wasm,cgo
|
|
|
|
package sqlutil
|
|
|
|
import (
|
|
"github.com/lib/pq"
|
|
"github.com/mattn/go-sqlite3"
|
|
)
|
|
|
|
// IsUniqueConstraintViolationErr returns true if the error is an unique_violation error
|
|
func IsUniqueConstraintViolationErr(err error) bool {
|
|
switch e := err.(type) {
|
|
case *pq.Error:
|
|
return e.Code == "23505"
|
|
case *sqlite3.Error:
|
|
return e.Code == sqlite3.ErrConstraint
|
|
case sqlite3.Error:
|
|
return e.Code == sqlite3.ErrConstraint
|
|
}
|
|
return false
|
|
}
|