一个支持Promise的nodejs下openstack-swift客户端

栏目: Node.js · 发布时间: 6年前

内容简介:最近由于需要,需要开发一个前端中间层用于管理对象存储,github粗略搜了一圈并没有找到如意的库,只能自己撸,还好30多年的麒麟臂没白练。这是一个支持promise的针对openstack-swift的nodejs客户端

最近由于需要,需要开发一个前端中间层用于管理对象存储,github粗略搜了一圈并没有找到如意的库,只能自己撸,还好30多年的麒麟臂没白练。

swift-nodeclient

这是一个支持promise的针对openstack-swift的nodejs客户端

如何使用它.

example

如何安装它.

$ npm i swift-nodeclient -save
复制代码

如何运行Demo.

$ node ./example/index.js
复制代码

API

const client = new NodeSwift({
    host: "127.0.0.1", // the location of swift server, if not assign port ,will only use host option.
    port: 12345, // the port of swift server
    authUrl: '' // the auth url .default /auth/v1.0
  });
  
  /**
   * Login
   * 
   * @param {String|required} account  
   * @param {String|required} user     
   * @param {String|required} password 
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.login({
    account: 'test',
    user:'tester',
    password:'testing'
  }).then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })
  
  /**
   * Get Container list
   * 
   * @return {Promise} success 
   *    {
   *      "status": "ok",
   *      "msg": {
   *        "bytesUsed": "545636",
   *        "containerCount": "2",
   *        "objectCount": "2",
   *        "data": [
   *          "test",
   *          "test1"
   *        ]
   *      }
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.getContainers().then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Create a new Container
   * 
   * @param {String|required} container 
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.newContainer('test').then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Create a new Container
   * for option items ref: https://docs.openstack.org/swift/latest/overview_acl.html#container-acls
   * 
   * @param {String|required} container
   * @param {Object|option} { headers: {'X-Container-Read': '.r:* | .r:<referrer>' } }
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.newContainer('test1', {
    headers: {
      'X-Container-Read': '.r:*'
    }
  }).then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Delete a Container
   * 
   * @param {String|required} container
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.delContainer('test1').then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Create a text Object
   * 
   * @param {String|required} container
   * @param {String|required} object
   * @param {String|Stream|required} data
   * @param {Object|option} { headers: {'Content-Type': 'text/html' } }
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.newObject('test', 'object1', 'hello world', {
    headers: {
      'Content-Type': 'text/html'
    }
  }).then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  const stream = fs.createReadStream('./example/WechatIMG127.jpeg');
  /**
   * Create a text Object
   * 
   * @param {String|required} container
   * @param {String|required} object
   * @param {String|Stream|required} data
   * @param {Object|option} { headers: {'Content-Type': 'image/jpeg' } }
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.newObject('test', 'object2', stream, {
    headers: {
      'Content-Type': 'image/jpeg'
    }
  }).then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Update a Object
   * 
   * @param {String|required} container
   * @param {String|required} object
   * @param {String|Stream|required} data
   * @param {Object|option} { headers: {'Content-Type': 'image/jpeg' } }
   * 
   * @return {Promise} success 
   *    {
   *      status: 'ok',
   *      msg: null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.updateObject('test', 'object1', 'hello world two', {
    headers: {
      'Content-Type': 'text/html'
    }
  }).then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Get object list
   * 
   * @param {String|required} container
   * 
   * @return {Promise} success 
   *    {
   *      "status": "ok",
   *      "msg": {
   *        "bytesUsed": "545636",
   *        "objectCount": "2",
   *        "data": [
   *          "test",
   *          "test1"
   *        ]
   *      }
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.getObjects('test').then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * Delete a Object
   * 
   * @param {String|required} container
   * @param {String|required} object
   * 
   * @return {Promise} success 
   *    {
   *      "status": "ok",
   *      "msg": null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.delObject('test', 'object1').then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })

  /**
   * copy a Object to a new path
   * 
   * @param {String|required} fromContainer
   * @param {String|required} fromobject
   * @param {String|required} toContainer
   * @param {String|required} toObject
   * 
   * @return {Promise} success 
   *    {
   *      "status": "ok",
   *      "msg": null
   *    }
   * @return {Promise} failed 
   *    {
   *      status: 'ng',
   *      msg: {...}
   *    }
   */
  await client.copyObject('test', 'object2', 'test1', 'object1').then((d) => {
    printObj(d);
  }).catch((e) => {
    printErr(e);
  })
复制代码

以上所述就是小编给大家介绍的《一个支持Promise的nodejs下openstack-swift客户端》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

首席产品官1 从新手到行家

首席产品官1 从新手到行家

车马 / 机械工业出版社 / 2018-9-25 / 79

《首席产品官》共2册,旨在为产品新人成长为产品行家,产品白领成长为产品金领,最后成长为首席产品官(CPO)提供产品认知、能力体系、成长方法三个维度的全方位指导。 作者在互联网领域从业近20年,是中国早期的互联网产品经理,曾是周鸿祎旗下“3721”的产品经理,担任CPO和CEO多年。作者将自己多年来的产品经验体系化,锤炼出了“产品人的能力杠铃模型”(简称“杠铃模型”),简洁、直观、兼容性好、实......一起来看看 《首席产品官1 从新手到行家》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具