Merge branch 'master' into 7490-datamanager-dont-die-return-error
[arvados.git] / sdk / go / util / util.go
index f163a82570340455535c09a92bc7b30cad77f84d..6bc86250b4e369548d71e77ed38d07413d0d56a7 100644 (file)
@@ -3,9 +3,7 @@
 package util
 
 import (
-       "errors"
        "git.curoverse.com/arvados.git/sdk/go/arvadosclient"
-       "log"
 )
 
 func UserIsAdmin(arv arvadosclient.ArvadosClient) (is_admin bool, err error) {
@@ -17,40 +15,20 @@ func UserIsAdmin(arv arvadosclient.ArvadosClient) (is_admin bool, err error) {
        return u.IsAdmin, err
 }
 
-func SdkListResponseContainsAllAvailableItems(response map[string]interface{}) (containsAll bool, numContained int, numAvailable int) {
-       if value, ok := response["items"]; ok {
-               items := value.([]interface{})
-               {
-                       var itemsAvailable interface{}
-                       if itemsAvailable, ok = response["items_available"]; !ok {
-                               // TODO(misha): Consider returning an error here (and above if
-                               // we can't find items) so that callers can recover.
-                               log.Fatalf("API server did not return the number of items available")
-                       }
-                       numContained = len(items)
-                       numAvailable = int(itemsAvailable.(float64))
-                       // If we never entered this block, allAvailable would be false by
-                       // default, which is what we want
-                       containsAll = numContained == numAvailable
-               }
+// Returns the total count of a particular type of resource
+//
+//   resource - the arvados resource to count
+// return
+//   count - the number of items of type resource the api server reports, if no error
+//   err - error accessing the resource, or nil if no error
+func NumberItemsAvailable(client arvadosclient.ArvadosClient, resource string) (count int, err error) {
+       var response struct {
+               ItemsAvailable int `json:"items_available"`
        }
-       return
-}
-
-func IterateSdkListItems(response map[string]interface{}) (c <-chan map[string]interface{}, err error) {
-       if value, ok := response["items"]; ok {
-               ch := make(chan map[string]interface{})
-               c = ch
-               items := value.([]interface{})
-               go func() {
-                       for _, item := range items {
-                               ch <- item.(map[string]interface{})
-                       }
-                       close(ch)
-               }()
-       } else {
-               err = errors.New("Could not find \"items\" field in response " +
-                       "passed to IterateSdkListItems()")
+       sdkParams := arvadosclient.Dict{"limit": 0}
+       err = client.List(resource, sdkParams, &response)
+       if err == nil {
+               count = response.ItemsAvailable
        }
        return
 }