storage.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. 'use strict';
  2. const Service = require('ee-core').Service;
  3. const Storage = require('ee-core').Storage;
  4. const _ = require('lodash');
  5. /**
  6. * 数据存储
  7. * @class
  8. */
  9. class StorageService extends Service {
  10. constructor (ctx) {
  11. super(ctx);
  12. // lowdb数据库
  13. this.systemDB = Storage.JsonDB.connection('system');
  14. this.demoDB = Storage.JsonDB.connection('demo');
  15. this.systemDBKey = {
  16. cache: 'cache'
  17. };
  18. this.demoDBKey = {
  19. preferences: 'preferences',
  20. test_data: 'test_data'
  21. };
  22. // sqlite数据库
  23. this.demoSqliteDB = Storage.JsonDB.connection('demo.db', 'sqlite');
  24. }
  25. /*
  26. * 增 Test data
  27. */
  28. async addTestData(user) {
  29. const key = this.demoDBKey.test_data;
  30. if (!this.demoDB.db.has(key).value()) {
  31. this.demoDB.db.set(key, []).write();
  32. }
  33. const data = this.demoDB.db
  34. .get(key)
  35. .push(user)
  36. .write();
  37. return data;
  38. }
  39. /*
  40. * 删 Test data
  41. */
  42. async delTestData(name = '') {
  43. const key = this.demoDBKey.test_data;
  44. const data = this.demoDB.db
  45. .get(key)
  46. .remove({name: name})
  47. .write();
  48. return data;
  49. }
  50. /*
  51. * 改 Test data
  52. */
  53. async updateTestData(name= '', age = 0) {
  54. const key = this.demoDBKey.test_data;
  55. const data = this.demoDB.db
  56. .get(key)
  57. .find({name: name}) // 修改找到的第一个数据,貌似无法批量修改 todo
  58. .assign({age: age})
  59. .write();
  60. return data;
  61. }
  62. /*
  63. * 查 Test data
  64. */
  65. async getTestData(age = 0) {
  66. const key = this.demoDBKey.test_data;
  67. let data = this.demoDB.db
  68. .get(key)
  69. //.find({age: age}) 查找单个
  70. .filter(function(o) {
  71. let isHas = true;
  72. isHas = age === o.age ? true : false;
  73. return isHas;
  74. })
  75. //.orderBy(['age'], ['name']) 排序
  76. //.slice(0, 10) 分页
  77. .value();
  78. if (_.isEmpty(data)) {
  79. data = []
  80. }
  81. return data;
  82. }
  83. /*
  84. * all Test data
  85. */
  86. async getAllTestData() {
  87. const key = this.demoDBKey.test_data;
  88. if (!this.demoDB.db.has(key).value()) {
  89. this.demoDB.db.set(key, []).write();
  90. }
  91. let data = this.demoDB.db
  92. .get(key)
  93. .value();
  94. if (_.isEmpty(data)) {
  95. data = []
  96. }
  97. return data;
  98. }
  99. /*
  100. * 增 Test data (sqlite)
  101. */
  102. async addTestDataSqlite(user) {
  103. console.log("user:", user);
  104. }
  105. /*
  106. * 删 Test data (sqlite)
  107. */
  108. async delTestDataSqlite(name = '') {
  109. }
  110. /*
  111. * 改 Test data (sqlite)
  112. */
  113. async updateTestDataSqlite(name= '', age = 0) {
  114. }
  115. /*
  116. * 查 Test data (sqlite)
  117. */
  118. async getTestDataSqlite(age = 0) {
  119. }
  120. /*
  121. * all Test data (sqlite)
  122. */
  123. async getAllTestDataSqlite() {
  124. }
  125. }
  126. module.exports = StorageService;