You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
46 lines
1.5 KiB
46 lines
1.5 KiB
3 years ago
|
// Copyright (C) MongoDB, Inc. 2017-present.
|
||
|
//
|
||
|
// 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
|
||
|
|
||
|
package internal
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
"go.mongodb.org/mongo-driver/bson"
|
||
|
)
|
||
|
|
||
|
// StringSliceFromRawElement decodes the provided BSON element into a []string. This internally calls
|
||
|
// StringSliceFromRawValue on the element's value. The error conditions outlined in that function's documentation
|
||
|
// apply for this function as well.
|
||
|
func StringSliceFromRawElement(element bson.RawElement) ([]string, error) {
|
||
|
return StringSliceFromRawValue(element.Key(), element.Value())
|
||
|
}
|
||
|
|
||
|
// StringSliceFromRawValue decodes the provided BSON value into a []string. This function returns an error if the value
|
||
|
// is not an array or any of the elements in the array are not strings. The name parameter is used to add context to
|
||
|
// error messages.
|
||
|
func StringSliceFromRawValue(name string, val bson.RawValue) ([]string, error) {
|
||
|
arr, ok := val.ArrayOK()
|
||
|
if !ok {
|
||
|
return nil, fmt.Errorf("expected '%s' to be an array but it's a BSON %s", name, val.Type)
|
||
|
}
|
||
|
|
||
|
arrayValues, err := arr.Values()
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
strs := make([]string, 0, len(arrayValues))
|
||
|
for _, arrayVal := range arrayValues {
|
||
|
str, ok := arrayVal.StringValueOK()
|
||
|
if !ok {
|
||
|
return nil, fmt.Errorf("expected '%s' to be an array of strings, but found a BSON %s", name, arrayVal.Type)
|
||
|
}
|
||
|
strs = append(strs, str)
|
||
|
}
|
||
|
return strs, nil
|
||
|
}
|