rs3.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. var Gun = require('../gun');
  2. var Radisk = require('./radisk');
  3. var fs = require('fs');
  4. var Radix = Radisk.Radix;
  5. var u, AWS;
  6. Gun.on('create', function(root){
  7. this.to.next(root);
  8. var opt = root.opt;
  9. if(!opt.s3 && !process.env.AWS_S3_BUCKET){ return }
  10. //opt.batch = opt.batch || (1000 * 10);
  11. //opt.until = opt.until || (1000 * 3); // ignoring these now, cause perf > cost
  12. //opt.chunk = opt.chunk || (1024 * 1024 * 10); // 10MB // when cost only cents
  13. try{AWS = require('aws-sdk');
  14. }catch(e){
  15. console.log("aws-sdk is no longer included by default, you must add it to your package.json! `npm install aws-sdk`.");
  16. AWS_SDK_NOT_INSTALLED;
  17. }
  18. var opts = opt.s3 || (opt.s3 = {});
  19. opts.bucket = opts.bucket || process.env.AWS_S3_BUCKET;
  20. opts.region = opts.region || process.AWS_REGION || "us-east-1";
  21. opts.accessKeyId = opts.key = opts.key || opts.accessKeyId || process.env.AWS_ACCESS_KEY_ID;
  22. opts.secretAccessKey = opts.secret = opts.secret || opts.secretAccessKey || process.env.AWS_SECRET_ACCESS_KEY;
  23. if(opt.fakes3 = opt.fakes3 || process.env.fakes3){
  24. opts.endpoint = opt.fakes3;
  25. opts.sslEnabled = false;
  26. opts.bucket = opts.bucket.replace('.','p');
  27. }
  28. opts.config = new AWS.Config(opts);
  29. opts.s3 = opts.s3 || new AWS.S3(opts.config);
  30. opt.store = opt.store || Store(opt);
  31. });
  32. function Store(opt){
  33. opt = opt || {};
  34. opt.file = String(opt.file || 'radata');
  35. var opts = opt.s3, s3 = opts.s3;
  36. var c = {p: {}, g: {}, l: {}};
  37. var store = function Store(){};
  38. if(Store[opt.file]){
  39. console.log("Warning: reusing same S3 store and options as 1st.");
  40. return Store[opt.file];
  41. }
  42. Store[opt.file] = store;
  43. store.put = function(file, data, cb){
  44. var params = {Bucket: opts.bucket, Key: file, Body: data};
  45. //console.log("RS3 PUT ---->", (data||"").slice(0,20));
  46. Gun.obj.del(c.g, file);
  47. Gun.obj.del(c.l, 1);
  48. s3.putObject(params, cb);
  49. };
  50. store.get = function(file, cb){
  51. if(c.g[file]){ return c.g[file].push(cb) }
  52. var cbs = c.g[file] = [cb];
  53. var params = {Bucket: opts.bucket, Key: file||''};
  54. //console.log("RS3 GET ---->", file);
  55. s3.getObject(params, function(err, ack){
  56. //console.log("RS3 GOT <----", err, file, cbs.length, ((ack||{}).Body||'').toString().slice(0,20));
  57. Gun.obj.del(c.g, file);
  58. var data, cbe = function(cb){
  59. if(!ack){ cb(null); return; }
  60. cb(err, data);
  61. };
  62. data = (ack||{}).Body; //if(data = (ack||{}).Body){ data = data.toString() }
  63. Gun.obj.map(cbs, cbe);
  64. });
  65. };
  66. store.list = function(cb, match, params, cbs){
  67. if(!cbs){
  68. if(c.l[1]){ return c.l[1].push(cb) }
  69. cbs = c.l[1] = [cb];
  70. }
  71. params = params || {Bucket: opts.bucket};
  72. //console.log("RS3 LIST --->");
  73. s3.listObjectsV2(params, function(err, data){
  74. //console.log("RS3 LIST <---", err, data, cbs.length);
  75. if(err){ return Gun.log(err, err.stack) }
  76. var IT = data.IsTruncated, cbe = function(cb){
  77. if(cb.end){ return }
  78. if(Gun.obj.map(data.Contents, function(content){
  79. return cb(content.Key);
  80. })){ cb.end = true; return }
  81. if(IT){ return }
  82. // Stream interface requires a final call to know when to be done.
  83. cb.end = true; cb();
  84. }
  85. Gun.obj.map(cbs, cbe);
  86. if(!IT){ Gun.obj.del(c.l, 1); return }
  87. params.ContinuationToken = data.NextContinuationToken;
  88. store.list(cb, match, params, cbs);
  89. });
  90. };
  91. //store.list(function(){ return true });
  92. return store;
  93. }
  94. module.exports = Store;