aboutsummaryrefslogtreecommitdiffstats
path: root/include/cynara/cynara-plugin.h
blob: 747966f07c86645db2d29b5c4c6638713142e5a0 (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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
 * Copyright (c) 2014-2015 Samsung Electronics Co., Ltd All Rights Reserved
 *
 *    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
 *
 *    Unless required by applicable law or agreed to in writing, software
 *    distributed under the License is distributed on an "AS IS" BASIS,
 *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *    See the License for the specific language governing permissions and
 *    limitations under the License.
 */
/**
 * @file        src/include/cynara-plugin.h
 * @author      Zofia Abramowska <z.abramowska@samsung.com>
 * @author      Oskar Switalski <o.switalski@samsung.com>
 * @version     1.0
 * @brief       This file defines cynara service side  of external plugin interface -
 *              ServicePluginInterface
 */

#ifndef CYNARA_PLUGIN_H_
#define CYNARA_PLUGIN_H_

#include <memory>
#include <string>
#include <vector>

#include <log/log.h>
#include <plugin/ExternalPluginInterface.h>
#include <types/PolicyResult.h>
#include <types/PolicyType.h>

namespace Cynara {

//These typedefs will be defined in external headers
typedef std::string PluginData;
typedef std::string AgentType;

class ServicePluginInterface;
typedef std::shared_ptr<ServicePluginInterface> ServicePluginInterfacePtr;

/**
 * A class defining external plugins interface.
 * These plugins work inside of cynara and either can produce
 * response through check instantly or require communication
 * with given type of agent. Agent must be registered through
 * cynara-agent API.
 *
 * Plugin implementing ServicePluginInterface must implement ExternalPluginInterface.
 * Creation/destruction functions with signatures compatible to Cynara::create_t and
 * Cynara::destroy_t must be provided as factories of ServicePluginInterface.
 */

class ServicePluginInterface : public ExternalPluginInterface {
public:
    /**
     * Enum indicating status of calling plugin method.
     */
    enum class PluginStatus {
        SUCCESS,                /**<  update() finished successfully */
        ANSWER_READY,           /**<  check() returns answer immediately through argument */
        ANSWER_NOTREADY,        /**<  check() cannot return answer immediately,
                                      communication with agent is required */
        ERROR                   /**<  either check() or update() fails */
    };

    /**
     * Asks plugin, what kind of permission does client, user and privilege has.
     *
     * @param[in] client
     * @param[in] user
     * @param[in] privilege
     * @param[out] result        Immediate response (if available)
     * @param[out] requiredAgent When ANSWER_NOTREADY, required AgentType to communicate with
     * @param[out] pluginData    Additional data, that will be passed to agent
     * @return PluginStatus      In case of success - either ANSWER_READY or ANSWER_NOTREADY,
     *                           in case of error - ERROR
     */
    virtual PluginStatus check(const std::string &client, const std::string &user,
                               const std::string &privilege, PolicyResult &result,
                               AgentType &requiredAgent, PluginData &pluginData) noexcept = 0;

    /**
     * Updates response returned by agent
     * @param[in] client
     * @param[in] user
     * @param[in] privilege
     * @param[in] agentData   Additional data, passed from agent
     * @param[out] result     Response interpreted from agent
     * @return PluginStatus   In case of success - SUCCESS, in case of error - ERROR
     */
    virtual PluginStatus update(const std::string &client, const std::string &user,
                                const std::string &privilege, const PluginData &agentData,
                                PolicyResult &result) noexcept = 0;

    virtual ~ServicePluginInterface() {};

};

} // namespace Cynara

#endif /* CYNARA_PLUGIN_H_ */