kitten-cloud-function
TypeScript icon, indicating that this package has built-in type declarations

1.2.0 • Public • Published

源码云功能

Gitee Repo stars Gitee Downloads (all assets, latest release) Gitee Downloads (all assets, latest release) Gitee License

GitHub Repo stars GitHub Downloads (all assets, latest release) GitHub Downloads (all assets, latest release) GitHub License

NPM Version NPM Downloads

一、介绍

1.简介

源码云功能是针对编程猫源码云功能(云变量、云列表等)的客户端工具,提供了多种使用方式。

2.主要功能

  • 查看、修改编程猫作品的云变量;
  • 获取编程猫作品的在线人数;
  • 获取当前登录的编程猫用户信息;
  • 查看、修改编程猫作品的云列表。

3.兼容性

在 Google Chrome 60、最新版的 Mozilla Firefox、Node 14 中测试正常。

CoCo 控件兼容 Creation Project,可在打包后的应用中使用。

4.其他

  • 该工具的默认配置尽可能地与源码编辑器保持一致。

二、快速开始

CoCo 控件版 代码版 命令行版

CoCo 控件版

1.获取 CoCo 控件

获取修改受限版

release 页面下载最新版本的 CoCo 控件 修改受限版。

修改受限版按照以下规则限制对云数据的修改:

1.在 CoCo 编辑器中,只能修改自己作品的云数据;

2.在已发布的 CoCo 作品中,只能修改该 CoCo 作品的作者的作品的云数据。

3.在 Creation Project 和打包后的应用中不可用。

为实现上述限制,源码云功能需要获取相关作品信息,因此,被连接的作品需要是已发布的;CoCo 作品如果发布,必须发布到社区。

获取专用版

专用版是只能特定的编程猫账号在特定 CoCo 作品中用于特定作品的特殊版本。这种版本严格限制了控件的用途,可以有效防止控件用于其他用途。

专用版在 Creation Project 和打包后的应用中可用。

请参考下面的命令自行构建专用版,多个用户或作品用英文逗号分开。

USER="你的编程猫账号ID"
USING_WORK="使用控件的CoCo作品的ID"
CONNECTING_WORK="要连接的作品的ID"

git clone https://gitee.com/slightning/Kitten-Cloud-Function.git
cd Kitten-Cloud-Function
npm install
npx wabpeck --config coco-widget.webpack.config.js --env user=$USER --env usingWork=$USING_WORK --env connectingWork=$CONNECTING_WORK

注:wabpeck是为提高门槛有意而为之的,请自行纠正。

获取完整版

完整版不应该用在公开作品(包括发布的作品)中。公开作品并不安全,可能导致控件泄露。

由于完整版功能过于强大,源码云功能不提供任何完整版 CoCo 控件和构建完整版 CoCo 控件的说明文档,有需求的请自行摸索。

2.检测用户登陆状态

使用用户已登录积木检测用户是否已登录。

提示:可以使用用户登录积木让用户登录。

3.连接到云

在进行除获取当前登录的用户信息之外的任何操作都需要在连接到云后进行。

使用连接 到 (0)积木进行连接,其中(0)填写要连接的作品的 ID。

注意:

  • 连接后进行依赖于连接的操作时,会自动等待连接完成。
  • 连接云时需要处在未连接状态,如果存在连接,上一个连接会自动断开。

4.查看和修改云数据

该操作与源码编辑器的操作类似,在此不再赘述。

5.获取用户信息

使用ID 为 (0) 的用户 的 [ID]积木,当 ID 为 0 时,获取到的是当前登录的用户的信息。

代码版

1.引入

npm

安装

$ npm install kitten-cloud-function

导入

import { KittenCloudFunction } from "kitten-cloud-function"
浏览器
<script src="https://cdn.jsdelivr.net/npm/axios@1/dist/axios.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/diff@7/dist/diff.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/crypto-browserify@3/example/bundle.js"></script>
<script>
    window.crypto = require("crypto")
</script>
<script src="https://cdn.jsdelivr.net/npm/kitten-cloud-function-browser@3/dist/kitten-cloud-function-browser.min.js"></script>
<script>
    const { KittenCloudFunction } = window.KittenCloudFunction
    // Your code here...
</script>

2.检测用户登陆状态

可以通过尝试获取用户信息来检测用户是否已登录。

try{
    await KittenCloudFunction.user.info.id
    console.log("用户已登录")
} catch(error) {
    console.log("用户未登录")
}

提示:在浏览器中,可以调用CodemaoUser.userLogInInBrowser让用户登录;在 Node 中,可以调用CodemaoUser.setAuthorization来设置登录凭证。

3.创建连接

let connection = new KittenCloudFunction(114514)

4.查看和修改云数据

①获取云数据实例
let connection = new KittenCloudFunction(114514)

// 快速获取云数据实例,不推荐使用
let data = await connection.get("云数据")

// 按照类型获取云数据实例
let privateVariable = await connection.privateVariable.get("私有云变量")
let publicVariable = await connection.publicVariable.get("公有云变量")
let list = await connection.list.get("云列表")
②查看和修改云变量
let connection = new KittenCloudFunction(114514)
let variable = await connection.publicVariable.get("云变量")

// 读取云变量的值
console.log(variable.get())

// 修改云变量的值
variable.set("好耶")

// 使用 await 等待上传
await variable.set("好耶!是源码云功能 v1.2.0,我们有救了!")
③查看私有云变量排行榜
let connection = new KittenCloudFunction(114514)
let privateVariable = await connection.privateVariable.get("私有云变量")

// 获取私有云变量排行榜逆序排列的前 31 名用户
let rankList = await privateVariable.getRankingList(31, -1)
for (const item of rankList) {
    console.log(item.value, await item.user.info.nickname)
}
④查看和修改云列表
let connection = new KittenCloudFunction(114514)
let list = await connection.list.get("云列表")

// 获取云列表索引为 1 的项,列表索引从 0 开始
console.log(list.get(1))

// 修改云列表索引为 1 的项
list.replace(1, "好耶")

// 添加云列表第索引为 10 的项,新添加的项的索引为 10
list.add(10, "好耶")

// 删除云列表索引为 1 的项
list.remove(1)

更多云列表操作请参考源码云功能 API 文档

5.更多功能

请参考源码云功能 API 文档

命令行版

1.安装

$ npm install kitten-cloud-function -g

2.设置身份

$ kcf set-authorization

3.设置作品

$ kcf use <work-id>

4.进行云操作

请参考:

$ kcf help

5.退出

$ kcf exit

三、功能配置

1.自动重连

当连接异常断开时,如果允许,会在等待指定时间后自动重连。

2.本地预更新

在没有开启本地预更新时,每次在本地执行数据更新操作时,都会等到该操作同步到云端并收到来自服务器的反馈后再更新本地的数据,这与普通的变量在修改后立即更新其值并不相同。

如:

let connection = new KittenCloudFunction(114514)

// 假设该变量初始值为 0
let variable = await connection.publicVariable.get("云变量")

// 此处应输出 0
console.log(variable.get())

// 修改变量的值,要等到该操作同步到云端并收到来自服务器的反馈后才能生效
variable.set(666)

// 此处仍然输出 0,因为对该变量的修改操作还没有同步到云端
console.log(variable.get())

开启本地预更新后,本地执行数据更新操作时,会假定该操作同步到云端之前没有其它用户对该数据进行操作,并基于此提前更新本地的数据,如果假定不成立,则会修正本地数据。具体而言,本地执行数据更新操作时,会立即更新本地的数据,如果在当前操作被同步到云端之前收到了来自服务器的反馈的其它更新数据,则会撤销本地对数据的更改,并执行来自云端的更改,最后再执行本地对数据的更改。

3.更多功能配置

请参考源码云功能 API 文档

四、技术信息

1.使用到的技术或工具

2.系统模块关系结构图

graph TD
subgraph CodemaoAPI["编程猫 API"]
    CodemaoInfoAPI(("编程猫信息 API<br>(外部模块)"))
    CodemaoWorkCloudAPI(("编程猫作品云功能 API<br>(外部模块)"))
end
CodemaoInfoAPI <--> CodemaoInfoAPIAdapter
CodemaoWorkCloudAPI <--> CodemaoWorkCloudAPIAdapter
subgraph KittenCloudFunctionModule ["源码云功能模块"]
    subgraph CodemaoAPIAdapter["编程猫 API 适配器"]
        CodemaoInfoAPIAdapter["编程猫信息 API 适配器<br>(./src/codemao/**)"]
        CodemaoWorkCloudAPIAdapter["编程猫作品云功能 API 适配器<br>(./src/module/network/**)"]
    end
    subgraph KittenCloudFunctionCore["源码云功能核心模块"]
        CodemaoInfoAPIAdapter <--> KittenCloudFunction["源码云功能主类<br>(./src/kitten-cloud-function.KittenCloudFunction)"]
        CodemaoWorkCloudAPIAdapter <--> KittenCloudFunction
        KittenCloudFunction <--> KittenCloudDataGroup["云数据组<br>(./src/module/cloud-data/group/*)"]
        KittenCloudDataGroup <--> KittenCloudData["云数据<br>(./src/module/cloud-data/*)"]
        KittenCloudDataGroup <--> KittenCloudDataUpdateManager["云数据更新管理器<br>(./src/module/cloud-data/update/**)"]
        KittenCloudDataUpdateManager <--> KittenCloudData
    end
    KittenCloudFunction <--> KittenCloudFunctionAPI
    KittenCloudDataGroup <--> KittenCloudFunctionAPI
    KittenCloudData <--> KittenCloudFunctionAPI
    KittenCloudFunctionAPI <--> SLIGHTNINGCoCoWidgetAdapter
    KittenCloudFunctionAPI <--> KittenCloudFunctionCLI
    subgraph KittenCloudFunctionInteractiveInterface["交互接口"]
        KittenCloudFunctionAPI(["源码云功能 API"])
        SLIGHTNINGCoCoWidgetAdapter["SLIGHTNING CoCo 控件框架适配器<br>(./src/wrapper/kitten-cloud-function-codemao-coco-widget)"]
        KittenCloudFunctionCLI(["源码云功能命令行界面"])
    end
end
KittenCloudFunctionAPI <--> Application
SLIGHTNINGCoCoWidgetAdapter <--> SLIGHTNINGCoCoWidget[["SLIGHTNING CoCo 控件框架<br>(slightning-coco-widget)"]] <--> CoCoWidgetAPI(("CoCo 自定义控件 API<br>(外部模块)")) <--> CoCoWork
KittenCloudFunctionCLI <--> User
subgraph Apply["应用"]
    Application["应用程序"]
    CoCoWork["CoCo 作品"]
    User((("用户")))
end

Package Sidebar

Install

npm i kitten-cloud-function

Weekly Downloads

2

Version

1.2.0

License

AGPL-3.0

Unpacked Size

1.05 MB

Total Files

187

Last publish

Collaborators

  • slightning