跳到主要內容

Slack 新增 Bot App


Create New App

1. Create New App

填入 App Name 及 選擇 workspace

2. 維護 Base Information

維護 App Name & Short description & App icon & background color

3. 維護 Oauth & Permissions

Add an Oauth Scope
incoming-webhook 

channels:read
This scope lets an app "View basic information about public channels in the workspace"

chat:write:bot
This scope lets an app "Send messages as your slack app"

4. Install App into your workspace

Code Example

Send messages example

DotNet Code Send Message 2 Slack



private void send2stalck(string path,string query,string header,string body,string message)
{
    Dictionary dictQuery = new Dictionary();
    dictQuery.Add("channel", @"slack channel");
    dictQuery.Add("token", @"slack token");
    dictQuery.Add("text", message);
    JArray jaFields = new JArray();
    var joEnv = new JObject() { { "title", "env" }, { "value", Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT") }, { "short", true } };
    var joPath = new JObject() { { "title", "path" }, { "value", path }, { "short", true } };
    var joTimestamp = new JObject() { { "title", "timestamp" }, { "value", System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") }, { "short", true } };
    var joQuery = new JObject() { { "title", "query parameter" }, { "value", query }, { "short", true } };
    var joHeader = new JObject() { { "title", "header parameter" }, { "value", header }, { "short", false } };
    var joBody = new JObject() { { "title", "body" }, { "value", body }, { "short", false } };
    var joMessage = new JObject() { { "title", "message" }, { "value", message }, { "short", false } };
    jaFields.Add(joEnv);
    jaFields.Add(joPath);
    jaFields.Add(joTimestamp);
    jaFields.Add(joQuery);
    jaFields.Add(joHeader);
    jaFields.Add(joBody);
    jaFields.Add(joMessage);
    JObject joField = new JObject() { { "fields", jaFields } };
    JArray ja = new JArray();
    ja.Add(joField);
    string strAttachments = JsonConvert.SerializeObject(ja);
    dictQuery.Add("attachments", WebUtility.UrlEncode(strAttachments));
    httpReqService service = new httpReqService().WithSlack();
    JObject joReturn = service.sendRequest("/chat.postMessage", "GET", dictQuery, null, null);
}
        

留言

這個網誌中的熱門文章

FluentD 存取 File Log

其他文章參考 FluentD 存取 Nginx Access Log (1/2) FluentD 存取 Nginx Access Log (2/2) 以上是 Nginx + FluentD + (ES|Mongo) Demo 針對access.log 做解析 現在以Log4X 產生的日誌檔作為範例說明 會遇到的問題有 日誌內容會有多行的情況 # multiline 希望每條日誌內容加入 UUID 以便追蹤 # https://github.com/chaeyk/fluent-plugin-add-uuid 使用 Slack 作為通知的通道 # https://github.com/sowawa/fluent-plugin-slack Log4X Layout Format Example <?xml version="1.0" encoding="utf-8" ?> <configuration> <log4net> <appender name="All" type="log4net.Appender.RollingFileAppender"> <file value="/var/log/web.log" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <datePattern value="yyyy-MM-dd" /> <maximumFileSize value="5MB" /> <maxSizeRollBackups value="10" /> <staticLogFileName value="true" /> <PreserveLogFileNameExtension value=...

申請免費 SSL,自動續訂

參考 acme.sh 搭配 GoDaddy 自動續期 Let's Encrypt 免費萬用憑證 使用 acme.sh + Cloudflare 申請免費 Wildcard SSL (Let’s Encrypt) 節略如下 安裝 acme.sh # 安裝 acme.sh ,安裝後重新登入 curl https://get.acme.sh | sh # 自動更新 acme.sh --upgrade --auto-upgrade acme.sh 設定存取 Goddy vi ~/.acme.sh/account.conf # Goddy API GD_Key="" GD_Secret="" acme.sh 設定存取 Cloudflare # Cloudflare API Keys # Global API Key [View] export CF_Key="" export CF_Email="" 申請網域(Domain)的萬用憑證,成功後會顯示憑證存放的路徑 $> acme.sh --issue --dns dns_gd -d ${domain} -d *.${domain} 安裝憑證 # 建立 /etc/nginx/ssl/${domain} 路徑 $> acme.sh --install-cert -d ${domain} --key-file /etc/nginx/ssl/${domain}/key.pem --fullchain-file /etc/nginx/ssl/${domain}/cert.pem --reloadcmd "sudo nginx -s reload"

DotNet Core 專案部署腳本

DotNet core SDK 首先在 Server 上準備編譯環境 Dockerfile #2.2 3.0 3.1 FROM mcr.microsoft.com/dotnet/core/sdk:3.1 RUN mkdir /web WORKDIR /web build docker image shell script docker build -t dotnetcoresdk:3.1 . start docker container shell script docker run -it -d \ --name dotnet-core-sdk-3.1 \ -v /opt/web:/web \ dotnetcoresdk:3.1 Jenkins Execute shell script on remote hosting using ssh #切換至專案目錄 cd /opt/web/project/path #取得最新版本 git pull #切換至專案目錄 && 刷新 Dotnet Library docker exec -i dotnet-core-sdk-3.1 bash -c "cd project/path && dotnet restore" #切換至專案目錄 && 刪除上一次編譯的檔案 && 編譯 docker exec -i dotnet-core-sdk-3.1 bash -c "cd project/path && rm -rf bin/Release && dotnet publish -c Release" #docker-compose.yml 參 DotNet core Runtime Section #!--rmi all 將原本執行的容器關閉並移除Image docker-compose down --rmi all #將新版程式包入 Image 並開始容器 docker-compose up -d DotNet core Runtime 專案中包含 Dockerfile & docker-compose.yml d...