系统集成实战:seafile

2024-01-23 02:44
文章标签 实战 seafile 系统集成

本文主要是介绍系统集成实战:seafile,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

        Seafile是一款强大优秀的云同步软件,拥有跨平台文件同步、移动端文件访问、挂载盘、文件共享和权限控制、文件锁定、文件版本管理和资料库镜像、在线编辑和协同编辑、审计日志等功能。

        为了进一步扩展它的可用业务,并将其集成到其他业务系统中。本文将给出一个python demo,其目的在于使用本地部署的seafile系统接口,将seafile功能通过api调用的形式拉出来单独进行操作。

demo

        这里集成了seafile api2及api/v2.1两款系统接口,为第三方系统+seafile的融合开发提供帮助。

        该代码仅用于学习分享目的,请勿滥用!

import os
import requests# 你的seafile信息
# 用户名、密码、项目地址根目录
username = 'xxx@qq.com'
password = 'xxxxxxx'
begin_url = 'http://127.0.0.1:1111/'class SeafileControl:def __init__(self):self.token = self.get_token()# 设置请求requests session保持对象self.session = requests.session()# token获取def get_token(self):headers = {'Content-Type': 'application/json'}datas = {'username': username, 'password': password}token = ''try:r = self.session.post(begin_url + 'api2/auth-token/', json=datas, headers=headers)print(r.json())token = r.json()['token']except Exception as e:print(e)finally:return token# 列出所有帐户def account_all(self):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  r = self.session.get(begin_url + 'api2/accounts/', headers=headers)return r.json()# 获得账户信息def account_msg(self, account):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json','Authorization': a}  r = self.session.get(begin_url + 'api2/accounts/' + account, headers=headers)return r.json()# 创建用户def accout_create(self, AccountName):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}# 给予默认密码xxxxdatas = {'password': 'xxxx'}response = self.session.put(begin_url + 'api2/accounts/' + AccountName + '/', json=datas, headers=headers)return response.text# 更新账户def account_update(self, AccountName):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  datas = {'password': '5999996', 'is_staff': 'true', 'storage': '1073741824'}response = self.session.put(begin_url + 'api2/accounts/' + AccountName + '/', json=datas, headers=headers)return response.text# 删除账户def account_delete(self, AccountName):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  response = self.session.delete(begin_url + 'api2/accounts/' + AccountName + '/', headers=headers)return response.textdef link_get(self):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  response = self.session.get(begin_url + 'api2/shared-links', headers=headers)return response.text# 查询所有库def repos_all(self):a = 'Token ' + self.tokenheaders = {'Authorization': a}  response = self.session.get(begin_url + 'api/v2.1/repos/', headers=headers)repos = {}for r in response.json()['repos']:repos.update({r['repo_name']: r['repo_id']})return repos# 增加库def repos_Insert(self, repos_name):a = 'Token ' + self.tokenheaders = {"Authorization": a, "Accept": "application/json; indent=4","content-type": "application/x-www-form-urlencoded"}  datas = {'name': repos_name, 'desc': 'new library'}response = self.session.post(begin_url + 'api2/repos/', headers=headers, data=datas)key = response.textreturn key.replace('"', '')# 删除库def repos_Delete(self, repos_id):a = 'Token ' + self.tokenheaders = {"Authorization": a, "Accept": "application/json; indent=4","content-type": "application/x-www-form-urlencoded"}  response = self.session.delete(begin_url + 'api2/repos/' + repos_id + '/', headers=headers)return response.text# 查询库/目录下的文件def file_all(self, repos_id, root_url):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  response = self.session.get(begin_url + 'api/v2.1/repos/' + repos_id + '/dir/?p=/{}&with_thumbnail=true'.format(root_url),headers=headers)repos = {}for r in response.json()['dirent_list']:repos_type = r['type']if repos_type not in repos:repos.update({repos_type: []})repos[repos_type].append(r['name'])return repos# 上传文件def file_Insert(self, repos_id, file_name, loca_file_url):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  r = self.session.get(begin_url + 'api2/repos/' + repos_id + '/upload-link/', headers=headers)key = r.text.replace('"', '')headers = {"Authorization": a}  file = {'file': (file_name, open(loca_file_url, 'rb')), 'parent_dir': '/'}response = self.session.post(key, files=file, headers=headers)return response.text# 上传目录def root_Insert(self, repos_id, root_name):a = 'Token ' + self.tokenheaders = {'Authorization': a}  data = {'operation': 'mkdir'}r = self.session.post(begin_url + 'api2/repos/' + repos_id + '/dir/?p=/{}'.format(root_name), data=data, headers=headers)return r.text# 文件更新def file_Update(self, repos_id, file_name, loca_file_url):a = 'Token ' + self.tokenheaders = {'Content-Type': 'application/json', 'Authorization': a}  r = self.session.get(begin_url + 'api2/repos/' + repos_id + '/update-link/?p=' + '/', headers=headers)key = r.text.replace('"', '')headers = {"Authorization": a}  file = {'file': (file_name, open(loca_file_url, 'rb')), 'parent_dir': '/', 'replace': 1,'target_file': '/' + file_name}response = self.session.post(key + '?ret-json=1', files=file, headers=headers)return response.text# 文件下载def file_DownLoad(self, repos_id, file_name):a = 'Token ' + self.tokenheaders = {"Authorization": a}  r = self.session.get(begin_url + 'api2/repos/' + repos_id + '/file/?p=/' + file_name, headers=headers)ret = Falsetry:# 分解目录路径和文件名dir_path = os.path.dirname(file_name)if not os.path.exists(dir_path):os.mkdir(dir_path)url = r.text.replace('"', '')target = self.session.get(url)f = open('DownLoad\\' + file_name, 'wb')# 将下载到的图片数据写入文件f.write(target.content)f.close()ret = Trueexcept Exception as e:print(e)finally:return ret, r.text# 文件重命名def root_Rename(self, repos_id, old_name, new_name):a = 'Token ' + self.tokenheaders = {"Authorization": a}  datas = {'operation': 'rename', 'newname': new_name}r = self.session.post(begin_url + 'api/v2.1/repos/' + repos_id + '/dir/?p=/' + old_name, headers=headers, data=datas)return r.text# 文件重命名def file_Rename(self, repos_id, old_name, new_name):a = 'Token ' + self.tokenheaders = {"Authorization": a}  datas = {'operation': 'rename', 'newname': new_name}r = self.session.post(begin_url + 'api/v2.1/repos/' + repos_id + '/file/?p=/' + old_name, headers=headers, data=datas)return r.text# 文件移动def file_Move(self, repos_id, file_url, file_name, target_repos_id, target_url):a = 'Token ' + self.tokenheaders = {"Authorization": a}  data = {"src_repo_id": repos_id, "src_parent_dir": file_url, "src_dirents": file_name,"dst_repo_id": target_repos_id,"dst_parent_dir": target_url}r = self.session.post(begin_url + 'api/v2.1/repos/sync-batch-move-item/', headers=headers, data=data)return r.text# 文件复制def file_Copy(self, repos_id, file_url, file_name, target_repos_id, target_url):a = 'Token ' + self.tokenheaders = {"Authorization": a}  data = {"src_repo_id": repos_id, "src_parent_dir": file_url, "src_dirents": file_name,"dst_repo_id": target_repos_id,"dst_parent_dir": target_url}r = self.session.post(begin_url + 'api/v2.1/repos/sync-batch-copy-item/', headers=headers, data=data)return r.json()# 文件删除def file_Delete(self, repos_id, file_url):a = 'Token ' + self.tokenheaders = {"Authorization": a, "Accept": "application/json; indent=4","content-type": "application/x-www-form-urlencoded"}  r = self.session.delete(begin_url + 'api2/repos/' + repos_id + '/file/?p=' + file_url, headers=headers)return r.text# 文件创建def file_Create(self, repos_id, file_url):a = 'Token ' + self.tokenheaders = {"Authorization": a, "Accept": "application/json; indent=4","content-type": "application/x-www-form-urlencoded"}  datas = {'operation': 'create'}r = self.session.post(begin_url + 'api2/repos/' + repos_id + '/file/?p=' + file_url, headers=headers, data=datas)return r.text# 文件历史查询def file_History(self, repos_id, file_url):a = 'Token ' + self.tokenheaders = {"Authorization": a, "Accept": "application/json; indent=4","content-type": "application/x-www-form-urlencoded"}  r = self.session.get(begin_url + 'api2/repos/' + repos_id + '/file/history/?p=' + file_url, headers=headers)return r.textif __name__ == '__main__':# token获得seafile = SeafileControl()print('token持续时长24小时,当前值为:', seafile.token)# 账户操作# accounts = seafile.account_all()# print(accounts)## for account in accounts:#     AccountMsg = seafile.account_msg(account['email'])#     print(AccountMsg)# links = seafile.link_get()# print(links)while True:repos_list = seafile.repos_all()print(repos_list)print('请选择您操作的方向:1为库操作,2为文件操作')menue = input()if menue == '1':print('请选择您要进行的操作:1为创建库、2为删除库')ch = input()if ch == '1':repos_name = input('新库名称:')back = seafile.repos_Insert(repos_name)print(back)elif ch == '2':repos_name = input('要删除的库名称:')repos_id = repos_list[repos_name]back = seafile.repos_Delete(repos_id)print(back)if menue == '2':print('需要对哪个库进行操作?')repos_name = input()repos_id = repos_list[repos_name]file_list = seafile.file_all(repos_id, '')print(file_list)while True:print('请选择您要进行的操作:0为创建空目录、1为上传文件、2为更新文件、3为下载文件、4为重命名文件、5为移动文件、6为拷贝文件、7为删除文件、8为创建文件(为空)、9为获取文件历史、10为查找目录文件、11为重命名目录')check = input()if check == '0':root_name = input('文件夹名:')back = seafile.root_Insert(repos_id, root_name)print(back)elif check == '1':file_name = input('文件名:')loca_file_url = input('文件地址:')back = seafile.file_Insert(repos_id, file_name, loca_file_url)print(back)elif check == '2':file_name = input('文件名:')loca_file_url = input('文件地址:')back = seafile.file_Update(repos_id, file_name, loca_file_url)print(back)elif check == '3':file_url = input('需要下载的文件名:')ret, back = seafile.file_DownLoad(repos_id, file_url)print(back)elif check == '4':old_name = input('旧文件名:')new_name = input('新文件名:')back = seafile.file_Rename(repos_id, old_name, new_name)print(back)elif check == '5':target_repos = input('目标库:')file_url = input('目标文件所在地址')file_name = input('目标文件').split('|')target_repos_id = repos_list[target_repos]target_url = input('目标目录:')back = seafile.file_Move(repos_id, file_url, file_name, target_repos_id, target_url)print(back)elif check == '6':target_repos = input('目标库:')file_url = input('目标文件所在地址')file_name = input('目标文件').split('|')target_repos_id = repos_list[target_repos]target_url = input('目标目录:')back = seafile.file_Copy(repos_id, file_url, file_name, target_repos_id, target_url)print(back)elif check == '7':file_url = input('需要删除的文件名:')back = seafile.file_Delete(repos_id, file_url)print(back)elif check == '8':file_url = input('需要创建的文件名(注意文件内容将为空):')back = seafile.file_Create(repos_id, file_url)print(back)elif check == '9':file_url = input('需要查看的文件名:')back = seafile.file_History(repos_id, file_url)print(back)elif check == '10':root_url = input('查看目录:')back = seafile.file_all(repos_id, root_url)print(back)elif check == '11':old_name = input('旧目录名:')new_name = input('新目录名:')back = seafile.root_Rename(repos_id, old_name, new_name)print(back)else:breakprint('----------------- 操作分割线 -----------------')

这篇关于系统集成实战:seafile的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/635000

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

springboot实战学习(1)(开发模式与环境)

目录 一、实战学习的引言 (1)前后端的大致学习模块 (2)后端 (3)前端 二、开发模式 一、实战学习的引言 (1)前后端的大致学习模块 (2)后端 Validation:做参数校验Mybatis:做数据库的操作Redis:做缓存Junit:单元测试项目部署:springboot项目部署相关的知识 (3)前端 Vite:Vue项目的脚手架Router:路由Pina:状态管理Eleme

深度学习实战:如何利用CNN实现人脸识别考勤系统

1. 何为CNN及其在人脸识别中的应用 卷积神经网络(CNN)是深度学习中的核心技术之一,擅长处理图像数据。CNN通过卷积层提取图像的局部特征,在人脸识别领域尤其适用。CNN的多个层次可以逐步提取面部的特征,最终实现精确的身份识别。对于考勤系统而言,CNN可以自动从摄像头捕捉的视频流中检测并识别出员工的面部。 我们在该项目中采用了 RetinaFace 模型,它基于CNN的结构实现高效、精准的

项目实战系列三: 家居购项目 第四部分

购物车 🌳购物车🍆显示购物车🍆更改商品数量🍆清空购物车&&删除商品 🌳生成订单 🌳购物车 需求分析 1.会员登陆后, 可以添加家居到购物车 2.完成购物车的设计和实现 3.每添加一个家居,购物车的数量+1, 并显示 程序框架图 1.新建src/com/zzw/furns/entity/CartItem.java, CartItem-家居项模型 /***

Birt报表开发实战

我就截图描述得了,没什么含金量,看图基本明白的。 1.开始 a.创建报表文件 b.数据源配置 c.配置数据集 2.网格报表 拖拉式操作,很方便 3.预览效果 其他报表的操作也基本不难,就不扯了! 2.级联参数 官方视频教程:http://demo.actuate.com/demos/cascade/cascade.html

[yolov5] --- yolov5入门实战「土堆视频」

1 项目介绍及环境配置 下载yolov5 tags 5.0源码,https://github.com/ultralytics/yolov5/tree/v5.0,解压 Pycharm 中创建conda虚拟环境 激活conda虚拟环境 根据作者提供的requirements.txt文件,pip install -r requirements.txt 如果作者没有提供requirement.txt文件

用Python实现时间序列模型实战——Day 14: 向量自回归模型 (VAR) 与向量误差修正模型 (VECM)

一、学习内容 1. 向量自回归模型 (VAR) 的基本概念与应用 向量自回归模型 (VAR) 是多元时间序列分析中的一种模型,用于捕捉多个变量之间的相互依赖关系。与单变量自回归模型不同,VAR 模型将多个时间序列作为向量输入,同时对这些变量进行回归分析。 VAR 模型的一般形式为: 其中: ​ 是时间  的变量向量。 是常数向量。​ 是每个时间滞后的回归系数矩阵。​ 是误差项向量,假