
akopulko/ffiiitc该Web服务用于执行交易分类,并与FireFly III(一款免费开源的个人财务管理工具)通过Web钩子集成。每当在FireFly III中添加新交易(手动或通过导入工具)时,Web钩子会触发并将交易描述发送至该服务,服务使用朴素贝叶斯分类器对交易进行分类,并更新匹配的类别。
适用于已部署FireFly III的个人用户,需要自动分类交易类别的场景。特别适合已有部分手动分类交易数据(至少1-2条)的用户,以提供初始训练样本。
选项->个人资料->OAuth,点击创建新令牌bashgit clone [***] cd ffiiitc docker buildx build --load --platform=linux/amd64 -t ffiiitc:latest .
在FireFly III的docker-compose.yml中添加以下配置:
基础配置:
yamlservices: fftc: image: akopulko/ffiiitc:latest hostname: fftc networks: - firefly_iii restart: always container_name: ffiiitc environment: - FF_API_KEY=<YOUR_PAT_GOES_HERE> # 替换为FireFly III的PAT - FF_APP_URL=<FIREFLY_ADDRESS:PORT> # 替换为FireFly III的地址和端口(如http://localhost:8080) volumes: - ffiiitc-data:/app/data # 存储训练模型 ports: - '<EXPOSED_PORT>:8080' # 替换为暴露的端口(如8081:8080) depends_on: - app # 依赖FireFly III的app服务 volumes: ffiiitc-data: # 声明数据卷
敏感信息保护(使用Docker Secrets):
yamlsecrets: ffiiitc-personal-access-token: file: "<path/to/secrets>/ffiiitc-personal-access-token" # 存储PAT的文件路径 services: fftc: # 其他配置同上 secrets: - "ffiiitc-personal-access-token" environment: - FF_API_KEY_FILE="/run/secrets/ffiiitc-personal-access-token" # 从secrets读取PAT - FF_APP_URL=<FIREFLY_ADDRESS:PORT>
bashdocker compose -f docker-compose.yml up -d
bashdocker run -d \ --name='ffiiitc' \ -e 'FF_API_KEY'='<YOUR_PAT_GOES_HERE>' \ -e 'FF_APP_URL'='<FIREFLY_ADDRESS:PORT>' \ -p '<EXPOSED_PORT>:8080' \ -v '<TRAINED_MODEL_FOLDER>:/app/data:rw' \ # 本地目录映射(如./ffiiitc-data:/app/data) 'ffiiitc'
自动化 -> Web钩子,点击创建新Web钩子[***]<EXPOSED_PORT>/classify(<EXPOSED_PORT>为docker-compose中配置的暴露端口)通过以下命令查看服务运行日志:
bashdocker compose logs fftc -f
如需重新训练模型,执行以下命令后重启fftc容器:
bashcurl -i http://localhost:<EXPOSED_PORT>/train
可添加日期参数限制训练数据范围(格式yyyy-mm-dd):
bashcurl -i "http://localhost:<EXPOSED_PORT>/train?start=2024-01-01&end=2024-06-01"
省略日期参数将使用所有可用交易数据训练。训练结果可通过日志确认。
注:朴素贝叶斯分类器使用navossoc/bayesian库,详细许可信息见其许可证。
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务