avatar

Slack beta platform - 試玩篇

Overview

前言

因為公司一開始就是遠端起身,溝通工具一直是蠻看重的一環(畢竟跟日常工作息息相關),所以也算蠻早就開始使用 Slack 作為主力的溝通工具,正因如此一些內部小工具都直接採用 Slack 平台上提供的許多功能,譬如 Bot、Slash command 之類的,然後看到它們提到已經開始下一代的開發者平台的消息(不過現在是內部測試,要申請通過才能使用),很好奇想玩玩看就申請看看了(然後就通過啦 🎉😄)

Slide

tech-share 因為玩完之後需要作個簡單的內部分享,所以就有上面這份了,如果只想簡單了解一下這是什麼東西的話,可以參考看看,不過因為很多東西還沒開放出來,所以也沒辦法寫太多細節。😆

天外飛來一恐龍(冷)

Slack chooses Deno for new development platform https://t.co/l1GbWXsJwv

— Deno (@deno_land){' '} November 16, 2021

順帶一提一個有趣的事,Slack 決定用 Deno 來打造它們的下一代平台喔 😙

如果還不知道 Deno 是什麼的話,可以看一下這場分享 - Deno is a New Way to JavaScript - Ryan Dahl & Kitson Kelly

Deno 跟 Node.js 應該算兄弟姊妹 😄,它們都是出自同一位作者 - Ryan Dahl,在他創造出 Node.js,以及後來看到它爆紅之後反思當初的一些設計並不是非常好(這場也是經典 - Design Mistakes in Node),所以他又做出了 Deno 這個新工具。

這邊就不再多介紹下去了,有興趣的話應該很容易可以找到 Deno 的簡介或相關學習資源,當然官方文件永遠是你最好上手的首選!

雖然 Deno 有種 Node.js 後繼者的姿態,不過它們雙方的架構相差頗大,生態圈也沒辦法完全相容(不過 Deno 團隊有在進行這塊的改善,像 Node compatibility mode 或是像 dnt 這類處理套件互通的工具),所以 Slack 下一代平台直接 all-in 在 Deno 也是頗大膽的行為。

Quick start

如果想玩玩這個新平台的話,首先你得先去申請加入,當然我猜個人開發者可能等好一陣子才有機會,但如果透過公司(使用者)的身分去申請,可能就會快得多,不過一些相關的專案倒也是可以在 Slack Github 裡面找到,用關鍵字 deno 就可以刮出不少了。😎

目前可以參考官方提供的範例 - reverse string這邊也還有其他更多範例可以參考),就可以稍微了解它的架構跟開發流程。

slack-beta-arch 目前的(beta platform)架構,很清楚是由三層元件組合而成的,就是 App 觸發(trigger的條件,以及觸發後所要執行的流程(workflow,與最後包含在流程中的每個行為(function。透過這樣的結構,可以很清楚的定義 App 的行為及功能。

beta-slack-arch 除了上面提及的 trigger/workflow/function 架構之外,還有幾個特別的小東西,構成 app 專案的基本結構:

踩雷之路

雖然看起來描繪的願景很美好,不過先來講些不好聽的話。😆

少到可憐的文件

目前雖然可以開發一些簡單的行為,不過還處於開發期的新平台,缺少大量文件是目前很大的痛點,很多只能透過現有的範例去兜弄。

比 beta 還不穩定的現狀

這部分跟它們採用截然不同的 Deno 來作為新平台的基石或許也有一些關係,畢竟跟 Node.js(或其他更成熟的技術)比較起來,Deno 就跟小嬰兒一樣,所以在開發上或許造成問題的可能性也更大。

我自己在試錯的過程中就遇到一個問題:「怎麼用 Private modules?」我想這應該也會是很多開發者會遇到的情境吧,但根據 Deno 的文件有提到 - Private modules 該怎麼處理,官方解法是透過一個環境變數 DENO_AUTH_TOKENS,把權限定義好,它就會自動處理。

[email protected]

這是它舉的例子,如果你的程式是擺在 Github 上面的話,就是定義好這樣(_注意是 raw.githubusercontent.com 而不是 github.com,因為 deno 會需要直接取程式的原始內容(RAW)_)

但是上面這個做法在 beta platform 是沒用的,目前一定要把認證放到 import_map.json 裡面才會生效(但把 secret 放進 VCS 不太好吧),這還只是諸多問題中其一而已,就是處處可能踩到雷。😅

驚豔

抱怨完之後再是得說說好話,畢竟目前看它描繪的未來真的很美!

超級方便的開發流程

之前的痛點有一部分在於麻煩的開發流程,測試、佈署都只能自己弄,如果希望有安全的測試環境,可能還得設定不同的 app 來測試。現在一切透過 beta platform 提供的 CLI 都變得超級簡單!

你想測試就 slack run 它就會很快起一個本地的測試,測試完沒問題要上線,就跑一下 slack deploy(對!你沒看錯,beta platform 連佈署都幫你處理好了),還有以往麻煩的 app 設定跟權限,一樣直接目錄下的 project.ts 裡面定義好就好,有種石器時代一口氣跳進工業時代的感覺。

講古一下

其實上述的開發工具,如果年紀夠大的開發者說不定有玩過類似的服務,之前有個叫 Beep Boop HQ 的新創就作了類似的東西,不過後來它改名叫 Missions之後,弄了一個設計流程的工具(沒錯你又猜對了,它就是現在 Slack 上面 Workflows builder 的前身,因為後來這間公司被 Slack 收購了,所以 beta platform 可以看到不少似曾相似的影子 😆

內建資料儲存

沒錯,現在存放資料不再需要另開資料庫了,beta platform 原生就可以直接有內建的資料庫可以使用(看起來後面是接 AWS DynamoDB,查詢直接支援相同的語法😄)。

結語

目前實測之後,比照目前的版本,在開發上真的有很大的改善,不過用 Deno 算是在技術鏈的選擇上蠻大膽的做法,再加上目前缺乏開發相關文件、資源,也不能保證它們會堅持到底。如前文提到,如果是一些簡單的小工具沒問題,然後就抱持著期待,希望 Slack 到時候能真的端出一個讓開發者驚豔的新一代開發平台。

powered by WebMention.io

You can skeet this post or discuss it on BlueSky, the comments will show up here.
0Likes0Replies0Mentions

Be the first one to share this article!