@fraym/sync 0.38.3 → 0.39.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"newConnection",{enumerable:true,get:function(){return newConnection}});var
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"newConnection",{enumerable:true,get:function(){return newConnection}});var _promise=require("./promise");function _array_like_to_array(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++)arr2[i]=arr[i];return arr2}function _array_with_holes(arr){if(Array.isArray(arr))return arr}function asyncGeneratorStep(gen,resolve,reject,_next,_throw,key,arg){try{var info=gen[key](arg);var value=info.value}catch(error){reject(error);return}if(info.done){resolve(value)}else{Promise.resolve(value).then(_next,_throw)}}function _async_to_generator(fn){return function(){var self=this,args=arguments;return new Promise(function(resolve,reject){var gen=fn.apply(self,args);function _next(value){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"next",value)}function _throw(err){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"throw",err)}_next(undefined)})}}function _iterable_to_array_limit(arr,i){var _i=arr==null?null:typeof Symbol!=="undefined"&&arr[Symbol.iterator]||arr["@@iterator"];if(_i==null)return;var _arr=[];var _n=true;var _d=false;var _s,_e;try{for(_i=_i.call(arr);!(_n=(_s=_i.next()).done);_n=true){_arr.push(_s.value);if(i&&_arr.length===i)break}}catch(err){_d=true;_e=err}finally{try{if(!_n&&_i["return"]!=null)_i["return"]()}finally{if(_d)throw _e}}return _arr}function _non_iterable_rest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _sliced_to_array(arr,i){return _array_with_holes(arr)||_iterable_to_array_limit(arr,i)||_unsupported_iterable_to_array(arr,i)||_non_iterable_rest()}function _unsupported_iterable_to_array(o,minLen){if(!o)return;if(typeof o==="string")return _array_like_to_array(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(n);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _array_like_to_array(o,minLen)}function _ts_generator(thisArg,body){var f,y,t,_={label:0,sent:function(){if(t[0]&1)throw t[1];return t[1]},trys:[],ops:[]},g=Object.create((typeof Iterator==="function"?Iterator:Object).prototype);return g.next=verb(0),g["throw"]=verb(1),g["return"]=verb(2),typeof Symbol==="function"&&(g[Symbol.iterator]=function(){return this}),g;function verb(n){return function(v){return step([n,v])}}function step(op){if(f)throw new TypeError("Generator is already executing.");while(g&&(g=0,op[0]&&(_=0)),_)try{if(f=1,y&&(t=op[0]&2?y["return"]:op[0]?y["throw"]||((t=y["return"])&&t.call(y),0):y.next)&&!(t=t.call(y,op[1])).done)return t;if(y=0,t)op=[op[0]&2,t.value];switch(op[0]){case 0:case 1:t=op;break;case 4:_.label++;return{value:op[1],done:false};case 5:_.label++;y=op[1];op=[0];continue;case 7:op=_.ops.pop();_.trys.pop();continue;default:if(!(t=_.trys,t=t.length>0&&t[t.length-1])&&(op[0]===6||op[0]===2)){_=0;continue}if(op[0]===3&&(!t||op[1]>t[0]&&op[1]<t[3])){_.label=op[1];break}if(op[0]===6&&_.label<t[1]){_.label=t[1];t=op;break}if(t&&_.label<t[2]){_.label=t[2];_.ops.push(op);break}if(t[2])_.ops.pop();_.trys.pop();continue}op=body.call(thisArg,_)}catch(e){op=[6,e];y=0}finally{f=t=0}if(op[0]&5)throw op[1];return{value:op[0]?op[1]:void 0,done:true}}}var newConnection=function(){return _async_to_generator(function(){var _ref,waitForStop,onStop,connected,onConnectCallbacks;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(0,_promise.createResolvablePromise)()];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForStop=_ref[0],onStop=_ref[1];connected=false;onConnectCallbacks=[];return[2,{connect:function(){return _async_to_generator(function(){var _iteratorNormalCompletion,_didIteratorError,_iteratorError,_iterator,_step,callback;return _ts_generator(this,function(_state){connected=true;_iteratorNormalCompletion=true,_didIteratorError=false,_iteratorError=undefined;try{for(_iterator=onConnectCallbacks[Symbol.iterator]();!(_iteratorNormalCompletion=(_step=_iterator.next()).done);_iteratorNormalCompletion=true){callback=_step.value;callback()}}catch(err){_didIteratorError=true;_iteratorError=err}finally{try{if(!_iteratorNormalCompletion&&_iterator.return!=null){_iterator.return()}}finally{if(_didIteratorError){throw _iteratorError}}}onConnectCallbacks=[];return[2]})})()},disconnect:function(){return _async_to_generator(function(){return _ts_generator(this,function(_state){connected=false;return[2]})})()},waitForConnect:function(){return _async_to_generator(function(){var _ref,waitForConnect,onConnect,response;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(0,_promise.createResolvablePromise)()];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForConnect=_ref[0],onConnect=_ref[1];if(connected){onConnect();return[2]}onConnectCallbacks.push(onConnect);return[4,(0,_promise.racePromises)({connect:waitForConnect(),stop:waitForStop()})];case 2:response=_state.sent();if(response==="stop"){onConnect();throw new Error("Stopping locking service...")}return[2]}})})()},stop:onStop}]}})})()};
|
package/dist/client/lease.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"createLease",{enumerable:true,get:function(){return createLease}});var
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"createLease",{enumerable:true,get:function(){return createLease}});var _ip=require("./ip");var _promise=require("./promise");var _retry=require("./retry");function _array_like_to_array(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++)arr2[i]=arr[i];return arr2}function _array_with_holes(arr){if(Array.isArray(arr))return arr}function asyncGeneratorStep(gen,resolve,reject,_next,_throw,key,arg){try{var info=gen[key](arg);var value=info.value}catch(error){reject(error);return}if(info.done){resolve(value)}else{Promise.resolve(value).then(_next,_throw)}}function _async_to_generator(fn){return function(){var self=this,args=arguments;return new Promise(function(resolve,reject){var gen=fn.apply(self,args);function _next(value){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"next",value)}function _throw(err){asyncGeneratorStep(gen,resolve,reject,_next,_throw,"throw",err)}_next(undefined)})}}function _iterable_to_array_limit(arr,i){var _i=arr==null?null:typeof Symbol!=="undefined"&&arr[Symbol.iterator]||arr["@@iterator"];if(_i==null)return;var _arr=[];var _n=true;var _d=false;var _s,_e;try{for(_i=_i.call(arr);!(_n=(_s=_i.next()).done);_n=true){_arr.push(_s.value);if(i&&_arr.length===i)break}}catch(err){_d=true;_e=err}finally{try{if(!_n&&_i["return"]!=null)_i["return"]()}finally{if(_d)throw _e}}return _arr}function _non_iterable_rest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _sliced_to_array(arr,i){return _array_with_holes(arr)||_iterable_to_array_limit(arr,i)||_unsupported_iterable_to_array(arr,i)||_non_iterable_rest()}function _unsupported_iterable_to_array(o,minLen){if(!o)return;if(typeof o==="string")return _array_like_to_array(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(n);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _array_like_to_array(o,minLen)}function _ts_generator(thisArg,body){var f,y,t,_={label:0,sent:function(){if(t[0]&1)throw t[1];return t[1]},trys:[],ops:[]},g=Object.create((typeof Iterator==="function"?Iterator:Object).prototype);return g.next=verb(0),g["throw"]=verb(1),g["return"]=verb(2),typeof Symbol==="function"&&(g[Symbol.iterator]=function(){return this}),g;function verb(n){return function(v){return step([n,v])}}function step(op){if(f)throw new TypeError("Generator is already executing.");while(g&&(g=0,op[0]&&(_=0)),_)try{if(f=1,y&&(t=op[0]&2?y["return"]:op[0]?y["throw"]||((t=y["return"])&&t.call(y),0):y.next)&&!(t=t.call(y,op[1])).done)return t;if(y=0,t)op=[op[0]&2,t.value];switch(op[0]){case 0:case 1:t=op;break;case 4:_.label++;return{value:op[1],done:false};case 5:_.label++;y=op[1];op=[0];continue;case 7:op=_.ops.pop();_.trys.pop();continue;default:if(!(t=_.trys,t=t.length>0&&t[t.length-1])&&(op[0]===6||op[0]===2)){_=0;continue}if(op[0]===3&&(!t||op[1]>t[0]&&op[1]<t[3])){_.label=op[1];break}if(op[0]===6&&_.label<t[1]){_.label=t[1];t=op;break}if(t&&_.label<t[2]){_.label=t[2];_.ops.push(op);break}if(t[2])_.ops.pop();_.trys.pop();continue}op=body.call(thisArg,_)}catch(e){op=[6,e];y=0}finally{f=t=0}if(op[0]&5)throw op[1];return{value:op[0]?op[1]:void 0,done:true}}}var createLease=function(connection,config,serviceClient){return _async_to_generator(function(){var ttl,locks,rLocks,leaseId,_ref,waitForStopExecution,stopExecution,_ref1,waitForStop,stopped,renew,keepLeaseAlive,runKeepalive,runDropLease;return _ts_generator(this,function(_state){switch(_state.label){case 0:ttl=20;locks=[];rLocks=[];leaseId="";return[4,(0,_promise.createResolvablePromise)()];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForStopExecution=_ref[0],stopExecution=_ref[1];return[4,(0,_promise.createResolvablePromise)()];case 2:_ref1=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForStop=_ref1[0],stopped=_ref1[1];renew=function(){return _async_to_generator(function(){var _ref,waitForCreateLease,onCreateLease,response;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(0,_promise.createResolvablePromise)()];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForCreateLease=_ref[0],onCreateLease=_ref[1];serviceClient.createLease({ip:(0,_ip.getOwnIpAddress)(),app:config.appPrefix,ttl:ttl,leaseId:leaseId,alreadyRegisteredLocks:getPbLocks(leaseId,locks),alreadyRegisteredRlocks:getPbLocks(leaseId,rLocks)},function(error,response){if(error){onCreateLease({error:error});return}onCreateLease({error:null,leaseId:response.leaseId})});return[4,waitForCreateLease()];case 2:response=_state.sent();if(response.error){throw response.error}leaseId=response.leaseId;keepLeaseAlive();return[4,connection.connect()];case 3:_state.sent();return[2]}})})()};keepLeaseAlive=function(){return _async_to_generator(function(){var response;return _ts_generator(this,function(_state){switch(_state.label){case 0:if(!true)return[3,5];return[4,(0,_promise.racePromises)({stop:waitForStopExecution(),keepalive:(0,_promise.wait)(ttl/2*1e3)})];case 1:response=_state.sent();if(!(response==="stop"))return[3,3];return[4,runDropLease()];case 2:_state.sent();return[2];case 3:return[4,runKeepalive()];case 4:if(!_state.sent()){return[2]}return[3,0];case 5:return[2]}})})()};runKeepalive=function(){return _async_to_generator(function(){var _ref,waitForKeepalive,onKeepalive,error,e;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(0,_promise.createResolvablePromise)()];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForKeepalive=_ref[0],onKeepalive=_ref[1];serviceClient.keepLease({leaseId:leaseId,ttl:ttl},onKeepalive);return[4,waitForKeepalive()];case 2:error=_state.sent();if(!error)return[3,7];return[4,connection.disconnect()];case 3:_state.sent();_state.label=4;case 4:_state.trys.push([4,6,,7]);return[4,(0,_retry.retry)(renew,100,50)];case 5:_state.sent();return[2,false];case 6:e=_state.sent();throw new Error("Unable to renew lease");case 7:return[2,true]}})})()};runDropLease=function(){return _async_to_generator(function(){var _ref,waitForDropped,onDrop,error;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,(0,_promise.createResolvablePromise)()];case 1:_ref=_sliced_to_array.apply(void 0,[_state.sent(),2]),waitForDropped=_ref[0],onDrop=_ref[1];serviceClient.dropLease({leaseId:leaseId},onDrop);return[4,waitForDropped()];case 2:error=_state.sent();if(error){throw error}stopped();return[2]}})})()};return[2,{stop:function(){stopExecution()},runWithLeaseId:function(callback){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,callback(leaseId)];case 1:_state.sent();return[2]}})})()},renew:renew,waitForStop:waitForStop,track:function(tenant,resource,read){return _async_to_generator(function(){return _ts_generator(this,function(_state){if(read){rLocks.push({tenant:tenant,resource:resource});return[2]}locks.push({tenant:tenant,resource:resource});return[2]})})()},untrack:function(tenant,resource,read){return _async_to_generator(function(){var found,newRLocks;return _ts_generator(this,function(_state){if(read){found=false;newRLocks=[];rLocks.forEach(function(lock){if(!found&&lock.tenant===tenant&&arraysEqual(lock.resource,resource)){found=true;return}newRLocks.push(lock)});rLocks=newRLocks;return[2]}locks=locks.filter(function(lock){return lock.tenant!==tenant||!arraysEqual(lock.resource,resource)});return[2]})})()}}]}})})()};var arraysEqual=function(a,b){if(a.length!==b.length){return false}for(var i=0;i<a.length;i++){if(a[i]!==b[i]){return false}}return true};var getPbLocks=function(leaseId,locks){return locks.map(function(lock){return{leaseId:leaseId,tenantId:lock.tenant,resource:lock.resource}})};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@fraym/sync",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.39.0",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"homepage": "https://github.com/fraym/freym-api",
|
|
6
6
|
"repository": {
|
|
@@ -22,9 +22,8 @@
|
|
|
22
22
|
"node": ">=20"
|
|
23
23
|
},
|
|
24
24
|
"dependencies": {
|
|
25
|
-
"@fraym/proto": "^0.
|
|
25
|
+
"@fraym/proto": "^0.39.0",
|
|
26
26
|
"@grpc/grpc-js": "^1.13.4",
|
|
27
|
-
"async-mutex": "^0.5.0",
|
|
28
27
|
"dotenv": "^16.5.0"
|
|
29
28
|
},
|
|
30
29
|
"prettier": "@becklyn/prettier"
|