server: Surround sqlite3 transactions with a lock to handle concurrency

This commit is contained in:
2013-07-19 22:15:53 -04:00
parent ada1317ec8
commit 24253d2e1e
2 changed files with 25 additions and 11 deletions

View File

@ -2,7 +2,6 @@ package main
import (
"asink"
"database/sql"
"encoding/json"
"flag"
"fmt"
@ -15,7 +14,7 @@ import (
//global variables
var eventsRegexp *regexp.Regexp
var port int = 8080
var db *sql.DB
var adb *AsinkDB
func init() {
var err error
@ -26,7 +25,7 @@ func init() {
eventsRegexp = regexp.MustCompile("^/events/([0-9]+)$")
db, err = GetAndInitDB()
adb, err = GetAndInitDB()
if err != nil {
panic(err)
}
@ -74,7 +73,7 @@ func getEvents(w http.ResponseWriter, r *http.Request, nextEvent uint64) {
w.Write(b)
}()
events, err := DatabaseRetrieveEvents(db, nextEvent, 50)
events, err := adb.DatabaseRetrieveEvents(nextEvent, 50)
if err != nil {
panic(err)
error_message = err.Error()
@ -126,7 +125,7 @@ func putEvents(w http.ResponseWriter, r *http.Request) {
return
}
for _, event := range events.Events {
err = DatabaseAddEvent(db, event)
err = adb.DatabaseAddEvent(event)
if err != nil {
//TODO should probably do this in a way that the caller knows how many of these have failed and doesn't re-try sending ones that succeeded
//i.e. add this to the return codes or something