Chilkat Online Tools

SQL Server / MeiliSearch v0.24 / Update settings

Back to Collection Items

-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
    DECLARE @hr int
    DECLARE @iTmp0 int
    -- Important: Do not use nvarchar(max).  See the warning about using nvarchar(max).
    DECLARE @sTmp0 nvarchar(4000)
    -- This example assumes the Chilkat API to have been previously unlocked.
    -- See Global Unlock Sample for sample code.

    DECLARE @http int
    -- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0
    EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    DECLARE @success int

    -- Use this online tool to generate code from sample JSON: Generate Code to Create JSON

    -- The following JSON is sent in the request body.

    -- {
    --   "searchableAttributes": [
    --     "title",
    --     "author"
    --   ],
    --   "stopWords": [
    --     "of",
    --     "the"
    --   ],
    --   "displayedAttributes": [
    --     "title",
    --     "author",
    --     "genre",
    --     "price"
    --   ],
    --   "filterableAttributes": [
    --     "genre",
    --     "price"
    --   ],
    --   "sortableAttributes": [
    --     "price"
    --   ]
    -- }

    DECLARE @json int
    -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0
    EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT

    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'searchableAttributes[0]', 'title'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'searchableAttributes[1]', 'author'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'stopWords[0]', 'of'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'stopWords[1]', 'the'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'displayedAttributes[0]', 'title'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'displayedAttributes[1]', 'author'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'displayedAttributes[2]', 'genre'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'displayedAttributes[3]', 'price'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'filterableAttributes[0]', 'genre'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'filterableAttributes[1]', 'price'
    EXEC sp_OAMethod @json, 'UpdateString', @success OUT, 'sortableAttributes[0]', 'price'

    EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'Content-Type', 'application/json'
    EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'X-Meili-Api-Key', 'masterKey'

    DECLARE @resp int
    EXEC sp_OAMethod @http, 'PostJson3', @resp OUT, 'http://localhost:7700/indexes/indexUID/settings', 'application/json', @json
    EXEC sp_OAGetProperty @http, 'LastMethodSuccess', @iTmp0 OUT
    IF @iTmp0 = 0
      BEGIN
        EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        EXEC @hr = sp_OADestroy @http
        EXEC @hr = sp_OADestroy @json
        RETURN
      END

    EXEC sp_OAGetProperty @resp, 'StatusCode', @iTmp0 OUT
    PRINT @iTmp0
    EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT
    PRINT @sTmp0
    EXEC @hr = sp_OADestroy @resp


    EXEC @hr = sp_OADestroy @http
    EXEC @hr = sp_OADestroy @json


END
GO

Curl Command

curl -X POST
	-H "X-Meili-Api-Key: masterKey"
	-H "Content-Type: application/json"
	-d '{
	"searchableAttributes": ["title", "author"],
	"stopWords": ["of", "the"],
    "displayedAttributes": ["title", "author", "genre", "price"],
    "filterableAttributes": ["genre", "price"],
    "sortableAttributes": ["price"]
}'
http://localhost:7700/indexes/indexUID/settings

Postman Collection Item JSON

{
  "name": "Update settings",
  "protocolProfileBehavior": {
    "disabledSystemHeaders": {
      "content-type": true
    }
  },
  "request": {
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "type": "text",
        "value": "application/json"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n\t\"searchableAttributes\": [\"title\", \"author\"],\n\t\"stopWords\": [\"of\", \"the\"],\n    \"displayedAttributes\": [\"title\", \"author\", \"genre\", \"price\"],\n    \"filterableAttributes\": [\"genre\", \"price\"],\n    \"sortableAttributes\": [\"price\"]\n}"
    },
    "url": {
      "raw": "{{url}}/indexes/{{indexUID}}/settings",
      "host": [
        "{{url}}"
      ],
      "path": [
        "indexes",
        "{{indexUID}}",
        "settings"
      ]
    }
  },
  "response": [
  ]
}