2011-02-03 06:42:31 +00:00
|
|
|
/*
|
|
|
|
Copyright 2011 Google Inc.
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2011-02-03 23:56:02 +00:00
|
|
|
package handlers
|
2011-02-03 06:42:31 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"camli/blobref"
|
2011-02-03 23:45:35 +00:00
|
|
|
"camli/blobserver"
|
2011-02-03 06:42:31 +00:00
|
|
|
"camli/httputil"
|
|
|
|
"fmt"
|
|
|
|
"http"
|
|
|
|
"log"
|
|
|
|
)
|
|
|
|
|
|
|
|
const maxRemovesPerRequest = 1000
|
|
|
|
|
2011-02-04 01:08:04 +00:00
|
|
|
func CreateRemoveHandler(storage blobserver.Storage, partition blobserver.Partition) func(http.ResponseWriter, *http.Request) {
|
2011-02-03 06:42:31 +00:00
|
|
|
return func(conn http.ResponseWriter, req *http.Request) {
|
2011-02-03 23:45:35 +00:00
|
|
|
handleRemove(conn, req, storage, partition)
|
2011-02-03 06:42:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-02-04 01:08:04 +00:00
|
|
|
func handleRemove(conn http.ResponseWriter, req *http.Request, storage blobserver.Storage, partition blobserver.Partition) {
|
2011-02-03 06:42:31 +00:00
|
|
|
if req.Method != "POST" {
|
|
|
|
log.Fatalf("Invalid method; handlers misconfigured")
|
|
|
|
}
|
|
|
|
|
|
|
|
if partition == "" {
|
|
|
|
conn.WriteHeader(http.StatusUnauthorized)
|
|
|
|
fmt.Fprintf(conn, "Can't remove blobs from the default partition.\n")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
n := 0
|
|
|
|
toRemove := make([]*blobref.BlobRef, 0)
|
|
|
|
toRemoveStr := make([]string, 0)
|
|
|
|
for {
|
|
|
|
n++
|
|
|
|
if n > maxRemovesPerRequest {
|
|
|
|
httputil.BadRequestError(conn,
|
|
|
|
fmt.Sprintf("Too many removes in this request; max is %d", maxRemovesPerRequest))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
key := fmt.Sprintf("blob%v", n)
|
|
|
|
value := req.FormValue(key)
|
|
|
|
if value == "" {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
ref := blobref.Parse(value)
|
|
|
|
if ref == nil {
|
|
|
|
httputil.BadRequestError(conn, "Bogus blobref for key "+key)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
toRemove = append(toRemove, ref)
|
|
|
|
toRemoveStr = append(toRemoveStr, ref.String())
|
|
|
|
}
|
|
|
|
|
2011-02-03 23:45:35 +00:00
|
|
|
err := storage.Remove(partition, toRemove)
|
2011-02-03 06:42:31 +00:00
|
|
|
if err != nil {
|
|
|
|
conn.WriteHeader(http.StatusInternalServerError)
|
|
|
|
log.Printf("Server error during remove: %v", err)
|
|
|
|
fmt.Fprintf(conn, "Server error")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
reply := make(map[string]interface{}, 0)
|
|
|
|
reply["removed"] = toRemoveStr
|
|
|
|
httputil.ReturnJson(conn, reply)
|
|
|
|
}
|