1

仅使用必填字段的死简单搜索查询:

{ schema_id: 'xxxxxxxx-8b39-427a-8fb8-c764957fd9c6',
filter: { last_name: { type: 'not', value: 'Smith' } } }

发布到https://api.truevault.com/v1/vaults/xxxxxxxx-15e3-442e-aa6f-xxxxxxxx/search

POST 时,POST 调用选项如下所示:

{ 
data: { search_option: 'xxxx base64 encoded JSON.stringify of the above xxxxxxx' },
headers: { Authorization: 'Basic xxx base64 encoded API KEY xxx' } 
}

授权有效。结果:

{错误:失败[400] {“错误”:{“代码”:“SEARCH.INVALID_SEARCH_QUERY”,“消息”:“无效搜索选项。”,“类型”:“无效请求错误”},
“结果”:“错误”, “transaction_id”:“9ad83046-1906-406c-87ab-963b904857c4”}

curl 命令用于相同的搜索查询:

curl -d "{ search_option: 'eyJzY2hlbWFfaWQiOiJlOWVmYmE0NC04YjMwLTQyN2EtOGZiOC1jNzY0OTU3ZmMwZGUiLCJmaWx0ZXIiOnsibGFzdF9uYW1lIjp7InR5cGUiOiJ3aWxkY2FyZCIsInZhbHVlIjoiRnJhbnptZWllcioifX19' }" 
-X POST 
-H "Content-Type: application/json" 
-H "Authorization: Basic xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx==" 
https://api.truevault.com/v1/vaults/xxxxxxxx-15e3-442e-aa6f-4xxxxxxxxxx/search

同样的错误:

{
    "error": {
        "code": "SEARCH.INVALID_SEARCH_QUERY",
        "message": "Invalid search_option.",
        "type": "invalid_request_error"
    },
    "result": "error",
    "transaction_id": "b5a51185-264f-4765-a1b8-6ae9e491aa39"
}
4

2 回答 2

0

亚历克斯,

我认为您的 curl 命令的格式不符合 TrueVault 的预期。这也可能是您的 http 库中的问题。我期望的 curl 命令是:

curl https://api.truevault.com/v1/vaults/xyz/search \
 -XPOST \
 -H "Content..."
 -H "Auth..."
 -d "search_option=eyJ...."

也就是说,数据有效负载是表单编码 ( param1=value1&param2=value2) 而不是 JSON。

看起来搜索文档缺少示例 curl,但您可以看到文档中列出的类似 curl文档创建。

于 2017-11-17T00:27:40.560 回答
0

我在我的 juery ajax 请求中遇到了我相信同样的问题。对我来说,我是用 发送我的请求header{'Content-Type':'application/json'},但它需要是表单数据。

工作示例:

var api_url = 'https://api.truevault.com/v1/vaults/' + vault_id + '/search';
var data = {
        'schema_id'    : schema_id,
        'page'         : 1,
        'per_page'     : 50,
        'filter_type'  : 'and',
        'full_document' : false,
        "sort": [
            {
                "SomeField":"asc"
            }
        ],
        'filter':{
            'SomeField':{
                'type':'eq',
                'value': somevalue
            }
        }
    };
data = btoa( JSON.stringify( data )  );

$.ajax({
    type     : 'POST',
    url      : api_url,
    dataType : 'json',
    processData : false,
    headers : {
        'Authorization':'Basic '+ btoa( auth_key+":" ),
    },
    mimeType : "multipart/form-data",
    data : 'search_option='+ data,
    error: function( response ) {
        //
    },
    success: function( response ) {
        //
    }
});
于 2020-09-18T19:04:01.407 回答