aboutsummaryrefslogtreecommitdiff
path: root/docker/tarantool/router.lua
blob: 359a8c49bb339fe73b7673ed249b3da6cbaef392 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
local vshard = require('vshard')
local log = require('log')

-- Bootstrap the vshard router.
while true do
    local ok, err = vshard.router.bootstrap({
        if_not_bootstrapped = true,
    })
    if ok then
        break
    end
    log.info(('Router bootstrap error: %s'):format(err))
end

-- functions for filer_metadata space
local filer_metadata = {
    delete_by_directory_idx = function(directory)
        -- find all storages
        local storages = require('vshard').router.routeall()
        -- on each storage
        for _, storage in pairs(storages) do
            -- call local function
            local result, err = storage:callrw('filer_metadata.delete_by_directory_idx', { directory })
            -- check for error
            if err then
                error("Failed to call function on storage: " .. tostring(err))
            end
        end
        -- return
        return true
    end,
    find_by_directory_idx_and_name = function(dirPath, startFileName, includeStartFile, limit)
        -- init results
        local results = {}
        -- find all storages
        local storages = require('vshard').router.routeall()
        -- on each storage
        for _, storage in pairs(storages) do
            -- call local function
            local result, err = storage:callro('filer_metadata.find_by_directory_idx_and_name', {
                dirPath,
                startFileName,
                includeStartFile,
                limit
            })
            -- check for error
            if err then
                error("Failed to call function on storage: " .. tostring(err))
            end
            -- add to results
            for _, tuple in ipairs(result) do
                table.insert(results, tuple)
            end
        end
        -- sort
        table.sort(results, function(a, b) return a[3] < b[3] end)
        -- apply limit
        if #results > limit then
            local limitedResults = {}
            for i = 1, limit do
                table.insert(limitedResults, results[i])
            end
            results = limitedResults
        end
        -- return
        return results
    end,
}

rawset(_G, 'filer_metadata', filer_metadata)

-- register functions for filer_metadata space, set grants
for name, _ in pairs(filer_metadata) do
    box.schema.func.create('filer_metadata.' .. name, { if_not_exists = true })
    box.schema.user.grant('app', 'execute', 'function', 'filer_metadata.' .. name, { if_not_exists = true })
    box.schema.user.grant('client', 'execute', 'function', 'filer_metadata.' .. name, { if_not_exists = true })
end