Skip to content

Latest commit

 

History

History
140 lines (106 loc) · 5.42 KB

README.MD

File metadata and controls

140 lines (106 loc) · 5.42 KB

ipaas-gateway

ipaas-gateway 是一个基于钉钉开放平台stream能力构建的系统。它允许用户在本地部署客户端代理(agent),以提供反向代理服务,连接内部服务与钉钉开放平台。

配置文件说明

ipaas-gateway 使用 YAML 格式的配置文件来配置代理的行为。配置文件中包含以下部分:

一个完整的配置文件示例

client:
  client_id: dingeypapxxxxxxxxxxx
  client_secret: xxxxxxxxxx7mQjlIF7q6YiFitxxxxxxxxxxxxxxxxxxxx
plugins:
  mssql:
    - host: localhost
      port: 1433
      address: localhost:1433
      user: sa
      password: sa123456A
      database: TestDB
      config_key: sqlServer
  mysql:
    - host: localhost
      port: 3306
      address: localhost:1433
      user: root
      password: root
      database: example
      config_key: default
  oracledb:
    - host: localhost
      port: 1521
      address: localhost:1521
      user: system
      password: example
      sid: FREE
      config_key: oracaldb
auth:
  mssql:
    allow_remote: true
  mysql:
    allow_remote: true
  pgsql:
    allow_remote: true

client 配置

  • client_id: 你的钉钉开放平台应用的客户端ID(AppKey),可以在钉钉开发者后台获取。
  • client_secret: 该应用的客户端密钥(AppSecret),同样在钉钉开发者后台获取。

这两个字段是必须的,因为它们用于身份验证和与钉钉开放平台的通信。

mysql 配置

配置文件中 plugin.mysql 部分是用来定义数据库连接的,它可以包含多个数据库配置(列表格式)。每个数据库配置包括以下字段:

  • host: 数据库服务器的主机名或IP地址。
  • port: 数据库服务器的端口号。
  • addr: 数据库服务器的地址和端口,通常格式为 hostname:port。可选字段,如果未提供,则使用 hostport 拼接。
  • username: 用于连接数据库的用户名称。
  • password: 用于连接数据库的密码。
  • database: 要连接的数据库名。
  • config_key: 此数据库配置的引用键名,用于在代码中引用特定数据库配置。

鉴权配置:

  • auth.allow_remote: 是否允许远程配置。如果设置为 true,则允许连接平台传入临时配置;如果设置为 false,则只允许本地配置文件的设置。

mssql 配置

配置文件中 plugin.mssql 部分是用来定义数据库连接的,它可以包含多个数据库配置(列表格式)。每个数据库配置包括以下字段:

  • host: 数据库服务器的主机名或IP地址。
  • port: 数据库服务器的端口号。
  • address: 数据库服务器的地址和端口,通常格式为 hostname:port。可选字段,如果未提供,则使用 hostport 拼接。
  • user: 用于连接数据库的用户名称。
  • password: 用于连接数据库的密码。
  • database: 要连接的数据库名。
  • config_key: 此数据库配置的引用键名,用于在代码中引用特定数据库配置。

鉴权配置:

  • auth.allow_remote: 是否允许远程配置。如果设置为 true,则允许连接平台传入临时配置;如果设置为 false,则只允许本地配置文件的设置。

oracledb 配置

配置文件中 plugin.oracledb 部分是用来定义数据库连接的,它可以包含多个数据库配置(列表格式)。每个数据库配置包括以下字段:

  • host: 数据库服务器的主机名或IP地址。
  • port: 数据库服务器的端口号。
  • address: 数据库服务器的地址和端口,通常格式为 hostname:port。可选字段,如果未提供,则使用 hostport 拼接。
  • user: 用于连接数据库的用户名称。
  • password: 用于连接数据库的密码。
  • service_name: 数据库的服务名。与 sid 二选一。
  • sid: 数据库的SID。与 service_name 二选一。
  • config_key: 此数据库配置的引用键名,用于在代码中引用特定数据库配置。

鉴权配置:

  • auth.allow_remote: 是否允许远程配置。如果设置为 true,则允许连接平台传入临时配置;如果设置为 false,则只允许本地配置文件的设置。

如何使用

在你的项目目录中添加一个名为 config.yml 的配置文件,根据上述字段填写对应的信息。例如:

client:
  client_id: dingeypapxxxxxxxxxxx
  client_secret: xxxxxxxxxx7mQjlIF7q6YiFitxxxxxxxxxxxxxxxxxxxx
plugins:
  mssql:
    - host: localhost
      port: 1433
      address: localhost:1433
      user: sa
      password: sa123456A
      database: TestDB
      config_key: sqlServer

确保 client 部分包含有效的 client_idclient_secretmysql 部分包含正确的数据库连接信息。

部署

  1. 进入钉钉开放平台,创建一个新的应用,并获取 client_idclient_secret
  2. 进入Release页面,下载最新版本的 ipaas-agent 本地网关。请选择适合你操作系统的版本。
  3. config.yaml 配置文件放在本地网关程序的根目录下。
  4. 启动代理,并确保它可以连接到钉钉开放平台以及配置的内部服务。

日志

在同一目录下,会产生 log1.txtlog2.txt 两个日志文件。

需要帮助?

如果你有任何疑问或需要帮助,可以查阅钉钉开放平台的文档,或者在项目的 issue 区提问。