@fraym/sync 1.0.0-alpha.22 → 1.0.0-alpha.23
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.
- package/dist/client/client.js +1 -1
- package/dist/client/lease.js +1 -1
- package/dist/client/lock.d.ts +2 -1
- package/dist/client/lock.js +1 -1
- package/dist/client/lockTracker.d.ts +9 -0
- package/dist/client/lockTracker.js +1 -0
- package/dist/client/rlock.d.ts +2 -1
- package/dist/client/rlock.js +1 -1
- package/dist/client/runlock.d.ts +2 -1
- package/dist/client/runlock.js +1 -1
- package/dist/client/tryLock.d.ts +2 -1
- package/dist/client/tryLock.js +1 -1
- package/dist/client/tryRLock.d.ts +2 -1
- package/dist/client/tryRLock.js +1 -1
- package/dist/client/unlock.d.ts +2 -1
- package/dist/client/unlock.js +1 -1
- package/package.json +2 -2
package/dist/client/client.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"newClient",{enumerable:true,get:function(){return newClient}});var _indexfreymsyncmanagement=require("@fraym/proto/dist/index.freym.sync.management");var _grpcjs=require("@grpc/grpc-js");var _config=require("./config");var _connection=require("./connection");var _lease=require("./lease");var _lock=require("./lock");var _requestGate=require("./requestGate");var _rlock=require("./rlock");var _runlock=require("./runlock");var _tryLock=require("./tryLock");var _tryRLock=require("./tryRLock");var _unlock=require("./unlock");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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 newClient=function newClient(config){return _async_to_generator(function(){var serviceClient,lockRequestGate,unlockRequestGate,connection,lease;return _ts_generator(this,function(_state){switch(_state.label){case 0:config=(0,_config.useConfigDefaults)(config);serviceClient=new _indexfreymsyncmanagement.ServiceClient(config.serverAddress,_grpcjs.credentials.createInsecure(),{"grpc.keepalive_time_ms":config.keepaliveInterval,"grpc.keepalive_timeout_ms":config.keepaliveTimeout,"grpc.keepalive_permit_without_calls":1,"grpc.max_receive_message_length":0x7fffffff});lockRequestGate=(0,_requestGate.newRequestGate)(900);unlockRequestGate=(0,_requestGate.newRequestGate)(80);return[4,(0,_connection.newConnection)()];case 1:connection=_state.sent();return[4,(0,_lease.createLease)(connection,config,serviceClient)];case 2:lease=_state.sent();return[4,lease.renew()];case 3:_state.sent();return[2,{lock:function lock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_lock.lock)(lease,tenantId,resource,serviceClient,lockRequestGate)];case 2:_state.sent();return[2]}})})()},tryLock:function tryLock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_tryLock.tryLock)(lease,tenantId,resource,serviceClient,lockRequestGate)];case 2:return[2,_state.sent()]}})})()},unlock:function unlock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_unlock.unlock)(lease,tenantId,resource,serviceClient,unlockRequestGate)];case 2:_state.sent();return[2]}})})()},rLock:function rLock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_rlock.rLock)(lease,tenantId,resource,serviceClient,lockRequestGate)];case 2:_state.sent();return[2]}})})()},tryRLock:function tryRLock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_tryRLock.tryRLock)(lease,tenantId,resource,serviceClient,lockRequestGate)];case 2:return[2,_state.sent()]}})})()},rUnlock:function rUnlock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_runlock.rUnlock)(lease,tenantId,resource,serviceClient,unlockRequestGate)];case 2:_state.sent();return[2]}})})()},close:function close(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:connection.stop();lease.stop();return[4,lease.waitForStop()];case 1:_state.sent();return[2]}})})()}}]}})})()};
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"newClient",{enumerable:true,get:function(){return newClient}});var _indexfreymsyncmanagement=require("@fraym/proto/dist/index.freym.sync.management");var _grpcjs=require("@grpc/grpc-js");var _config=require("./config");var _connection=require("./connection");var _lease=require("./lease");var _lock=require("./lock");var _lockTracker=require("./lockTracker");var _requestGate=require("./requestGate");var _rlock=require("./rlock");var _runlock=require("./runlock");var _tryLock=require("./tryLock");var _tryRLock=require("./tryRLock");var _unlock=require("./unlock");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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 newClient=function newClient(config){return _async_to_generator(function(){var serviceClient,lockRequestGate,unlockRequestGate,lockTracker,connection,lease;return _ts_generator(this,function(_state){switch(_state.label){case 0:config=(0,_config.useConfigDefaults)(config);serviceClient=new _indexfreymsyncmanagement.ServiceClient(config.serverAddress,_grpcjs.credentials.createInsecure(),{"grpc.keepalive_time_ms":config.keepaliveInterval,"grpc.keepalive_timeout_ms":config.keepaliveTimeout,"grpc.keepalive_permit_without_calls":1,"grpc.max_receive_message_length":0x7fffffff});lockRequestGate=(0,_requestGate.newRequestGate)(900);unlockRequestGate=(0,_requestGate.newRequestGate)(80);lockTracker=(0,_lockTracker.newLockTracker)();return[4,(0,_connection.newConnection)()];case 1:connection=_state.sent();return[4,(0,_lease.createLease)(connection,config,serviceClient)];case 2:lease=_state.sent();return[4,lease.renew()];case 3:_state.sent();return[2,{lock:function lock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_lock.lock)(lease,tenantId,resource,serviceClient,lockRequestGate,lockTracker)];case 2:_state.sent();return[2]}})})()},tryLock:function tryLock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_tryLock.tryLock)(lease,tenantId,resource,serviceClient,lockRequestGate,lockTracker)];case 2:return[2,_state.sent()]}})})()},unlock:function unlock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_unlock.unlock)(lease,tenantId,resource,serviceClient,unlockRequestGate,lockTracker)];case 2:_state.sent();return[2]}})})()},rLock:function rLock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_rlock.rLock)(lease,tenantId,resource,serviceClient,lockRequestGate,lockTracker)];case 2:_state.sent();return[2]}})})()},tryRLock:function tryRLock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_tryRLock.tryRLock)(lease,tenantId,resource,serviceClient,lockRequestGate,lockTracker)];case 2:return[2,_state.sent()]}})})()},rUnlock:function rUnlock(tenantId){for(var _len=arguments.length,resource=new Array(_len>1?_len-1:0),_key=1;_key<_len;_key++){resource[_key-1]=arguments[_key]}return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,connection.waitForConnect()];case 1:_state.sent();return[4,(0,_runlock.rUnlock)(lease,tenantId,resource,serviceClient,unlockRequestGate,lockTracker)];case 2:_state.sent();return[2]}})})()},close:function close(){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:connection.stop();lease.stop();return[4,lease.waitForStop()];case 1:_state.sent();return[2]}})})()}}]}})})()};
|
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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 createLease(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 renew(){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 keepLeaseAlive(){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 runKeepalive(){return _async_to_generator(function(){var _ref,waitForKeepalive,onKeepalive,error,unused;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:unused=_state.sent();throw new Error("Unable to renew lease");case 7:return[2,true]}})})()};runDropLease=function runDropLease(){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 stop(){stopExecution()},runWithLeaseId:function runWithLeaseId(callback){return _async_to_generator(function(){return _ts_generator(this,function(_state){
|
|
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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 createLease(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 renew(){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 keepLeaseAlive(){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 runKeepalive(){return _async_to_generator(function(){var _ref,waitForKeepalive,onKeepalive,error,unused;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:unused=_state.sent();throw new Error("Unable to renew lease");case 7:return[2,true]}})})()};runDropLease=function runDropLease(){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 stop(){stopExecution()},runWithLeaseId:function runWithLeaseId(callback){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,callback(leaseId)]})})()},renew:renew,waitForStop:waitForStop,track:function track(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 untrack(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 arraysEqual(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 getPbLocks(leaseId,locks){return locks.map(function(lock){return{leaseId:leaseId,tenantId:lock.tenant,resource:lock.resource}})};
|
package/dist/client/lock.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ServiceClient } from "@fraym/proto/dist/index.freym.sync.management";
|
|
2
2
|
import { Lease } from "./lease";
|
|
3
|
+
import { LockTracker } from "./lockTracker";
|
|
3
4
|
import { RequestGate } from "./requestGate";
|
|
4
|
-
export declare const lock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate) => Promise<void>;
|
|
5
|
+
export declare const lock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate, lockTracker: LockTracker) => Promise<void>;
|
package/dist/client/lock.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"lock",{enumerable:true,get:function(){return lock}});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"lock",{enumerable:true,get:function(){return lock}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 lock=function lock(lease,tenantId,resource,serviceClient,requestGate,lockTracker){return _async_to_generator(function(){var error;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,lockTracker.lock(tenantId,resource)];case 1:_state.sent();_state.label=2;case 2:_state.trys.push([2,4,,5]);return[4,requestGate.run(function(){return lease.runWithLeaseId(function(leaseId){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,new Promise(function(resolve,reject){serviceClient.lock({leaseId:leaseId,tenantId:tenantId,resource:resource},function(error){if(error){reject(error);return}resolve()})})]})})()})})];case 3:_state.sent();return[3,5];case 4:error=_state.sent();lockTracker.unlock(tenantId,resource);throw error;case 5:return[4,lease.track(tenantId,resource,false)];case 6:_state.sent();return[2]}})})()};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface LockTracker {
|
|
2
|
+
lock: (tenantId: string, resource: string[]) => Promise<void>;
|
|
3
|
+
tryLock: (tenantId: string, resource: string[]) => boolean;
|
|
4
|
+
unlock: (tenantId: string, resource: string[]) => void;
|
|
5
|
+
rLock: (tenantId: string, resource: string[]) => Promise<void>;
|
|
6
|
+
tryRLock: (tenantId: string, resource: string[]) => boolean;
|
|
7
|
+
rUnlock: (tenantId: string, resource: string[]) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare const newLockTracker: () => LockTracker;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"newLockTracker",{enumerable:true,get:function(){return newLockTracker}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 resourceKey=function resourceKey(tenantId,resource){return"".concat(tenantId,"\0").concat(resource.join("\0"))};var newLockTracker=function newLockTracker(){var writeLocked=new Set;var readLockCounts=new Map;var waitQueues=new Map;var isWriteLocked=function isWriteLocked(key){return writeLocked.has(key)};var isReadLocked=function isReadLocked(key){var _readLockCounts_get;return((_readLockCounts_get=readLockCounts.get(key))!==null&&_readLockCounts_get!==void 0?_readLockCounts_get:0)>0};var hasWaiters=function hasWaiters(key){var _ref;var _waitQueues_get;return((_ref=(_waitQueues_get=waitQueues.get(key))===null||_waitQueues_get===void 0?void 0:_waitQueues_get.length)!==null&&_ref!==void 0?_ref:0)>0};var notifyWaiters=function notifyWaiters(key){if(isWriteLocked(key)){return}var queue=waitQueues.get(key);if(!queue||queue.length===0){return}var head=queue[0];if(head.kind==="write"){if(!isReadLocked(key)){queue.shift();writeLocked.add(key);head.resolve()}return}var next=queue[0];while(next!==undefined&&next.kind==="read"){var _readLockCounts_get;queue.shift();readLockCounts.set(key,((_readLockCounts_get=readLockCounts.get(key))!==null&&_readLockCounts_get!==void 0?_readLockCounts_get:0)+1);next.resolve();next=queue[0]}};return{lock:function lock(tenantId,resource){return _async_to_generator(function(){var key;return _ts_generator(this,function(_state){key=resourceKey(tenantId,resource);return[2,new Promise(function(resolve){var _waitQueues_get;if(!isWriteLocked(key)&&!isReadLocked(key)&&!hasWaiters(key)){writeLocked.add(key);return}var queue=(_waitQueues_get=waitQueues.get(key))!==null&&_waitQueues_get!==void 0?_waitQueues_get:[];queue.push({kind:"write",resolve:resolve});waitQueues.set(key,queue)})]})})()},tryLock:function tryLock(tenantId,resource){var key=resourceKey(tenantId,resource);if(!isWriteLocked(key)&&!isReadLocked(key)&&!hasWaiters(key)){writeLocked.add(key);return true}return false},unlock:function unlock(tenantId,resource){var key=resourceKey(tenantId,resource);writeLocked.delete(key);notifyWaiters(key)},rLock:function rLock(tenantId,resource){return _async_to_generator(function(){var key;return _ts_generator(this,function(_state){key=resourceKey(tenantId,resource);return[2,new Promise(function(resolve){var _waitQueues_get;if(!isWriteLocked(key)&&!hasWaiters(key)){var _readLockCounts_get;var count=(_readLockCounts_get=readLockCounts.get(key))!==null&&_readLockCounts_get!==void 0?_readLockCounts_get:0;readLockCounts.set(key,count+1);return}var queue=(_waitQueues_get=waitQueues.get(key))!==null&&_waitQueues_get!==void 0?_waitQueues_get:[];queue.push({kind:"read",resolve:resolve});waitQueues.set(key,queue)})]})})()},tryRLock:function tryRLock(tenantId,resource){var key=resourceKey(tenantId,resource);if(!isWriteLocked(key)&&!hasWaiters(key)){var _readLockCounts_get;readLockCounts.set(key,((_readLockCounts_get=readLockCounts.get(key))!==null&&_readLockCounts_get!==void 0?_readLockCounts_get:0)+1);return true}return false},rUnlock:function rUnlock(tenantId,resource){var _readLockCounts_get;var key=resourceKey(tenantId,resource);var count=(_readLockCounts_get=readLockCounts.get(key))!==null&&_readLockCounts_get!==void 0?_readLockCounts_get:0;if(count<=1){readLockCounts.delete(key)}else{readLockCounts.set(key,count-1)}notifyWaiters(key)}}};
|
package/dist/client/rlock.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ServiceClient } from "@fraym/proto/dist/index.freym.sync.management";
|
|
2
2
|
import { Lease } from "./lease";
|
|
3
|
+
import { LockTracker } from "./lockTracker";
|
|
3
4
|
import { RequestGate } from "./requestGate";
|
|
4
|
-
export declare const rLock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate) => Promise<void>;
|
|
5
|
+
export declare const rLock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate, lockTracker: LockTracker) => Promise<void>;
|
package/dist/client/rlock.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"rLock",{enumerable:true,get:function(){return rLock}});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"rLock",{enumerable:true,get:function(){return rLock}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 rLock=function rLock(lease,tenantId,resource,serviceClient,requestGate,lockTracker){return _async_to_generator(function(){var error;return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,lockTracker.rLock(tenantId,resource)];case 1:_state.sent();_state.label=2;case 2:_state.trys.push([2,4,,5]);return[4,requestGate.run(function(){return lease.runWithLeaseId(function(leaseId){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,new Promise(function(resolve,reject){serviceClient.rLock({leaseId:leaseId,tenantId:tenantId,resource:resource},function(error){if(error){reject(error);return}resolve()})})]})})()})})];case 3:_state.sent();return[3,5];case 4:error=_state.sent();lockTracker.rUnlock(tenantId,resource);throw error;case 5:return[4,lease.track(tenantId,resource,true)];case 6:_state.sent();return[2]}})})()};
|
package/dist/client/runlock.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ServiceClient } from "@fraym/proto/dist/index.freym.sync.management";
|
|
2
2
|
import { Lease } from "./lease";
|
|
3
|
+
import { LockTracker } from "./lockTracker";
|
|
3
4
|
import { RequestGate } from "./requestGate";
|
|
4
|
-
export declare const rUnlock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate) => Promise<void>;
|
|
5
|
+
export declare const rUnlock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate, lockTracker: LockTracker) => Promise<void>;
|
package/dist/client/runlock.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"rUnlock",{enumerable:true,get:function(){return rUnlock}});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"rUnlock",{enumerable:true,get:function(){return rUnlock}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 rUnlock=function rUnlock(lease,tenantId,resource,serviceClient,requestGate,lockTracker){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,requestGate.run(function(){return lease.runWithLeaseId(function(leaseId){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,new Promise(function(resolve,reject){serviceClient.rUnlock({leaseId:leaseId,tenantId:tenantId,resource:resource},function(error){if(error){reject(error);return}resolve()})})]})})()})})];case 1:_state.sent();lockTracker.rUnlock(tenantId,resource);return[4,lease.untrack(tenantId,resource,true)];case 2:_state.sent();return[2]}})})()};
|
package/dist/client/tryLock.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ServiceClient } from "@fraym/proto/dist/index.freym.sync.management";
|
|
2
2
|
import { Lease } from "./lease";
|
|
3
|
+
import { LockTracker } from "./lockTracker";
|
|
3
4
|
import { RequestGate } from "./requestGate";
|
|
4
|
-
export declare const tryLock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate) => Promise<boolean>;
|
|
5
|
+
export declare const tryLock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate, lockTracker: LockTracker) => Promise<boolean>;
|
package/dist/client/tryLock.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"tryLock",{enumerable:true,get:function(){return tryLock}});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"tryLock",{enumerable:true,get:function(){return tryLock}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 tryLock=function tryLock(lease,tenantId,resource,serviceClient,requestGate,lockTracker){return _async_to_generator(function(){var locked,error;return _ts_generator(this,function(_state){switch(_state.label){case 0:if(!lockTracker.tryLock(tenantId,resource)){return[2,false]}locked=false;_state.label=1;case 1:_state.trys.push([1,3,,4]);return[4,requestGate.run(function(){return lease.runWithLeaseId(function(leaseId){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,new Promise(function(resolve,reject){serviceClient.tryLock({leaseId:leaseId,tenantId:tenantId,resource:resource},function(error,response){if(error){reject(error);return}locked=response.locked;resolve()})})]})})()})})];case 2:_state.sent();return[3,4];case 3:error=_state.sent();lockTracker.unlock(tenantId,resource);throw error;case 4:if(!locked){lockTracker.unlock(tenantId,resource);return[2,false]}return[4,lease.track(tenantId,resource,false)];case 5:_state.sent();return[2,true]}})})()};
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ServiceClient } from "@fraym/proto/dist/index.freym.sync.management";
|
|
2
2
|
import { Lease } from "./lease";
|
|
3
|
+
import { LockTracker } from "./lockTracker";
|
|
3
4
|
import { RequestGate } from "./requestGate";
|
|
4
|
-
export declare const tryRLock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate) => Promise<boolean>;
|
|
5
|
+
export declare const tryRLock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate, lockTracker: LockTracker) => Promise<boolean>;
|
package/dist/client/tryRLock.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"tryRLock",{enumerable:true,get:function(){return tryRLock}});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"tryRLock",{enumerable:true,get:function(){return tryRLock}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 tryRLock=function tryRLock(lease,tenantId,resource,serviceClient,requestGate,lockTracker){return _async_to_generator(function(){var locked,error;return _ts_generator(this,function(_state){switch(_state.label){case 0:if(!lockTracker.tryRLock(tenantId,resource)){return[2,false]}locked=false;_state.label=1;case 1:_state.trys.push([1,3,,4]);return[4,requestGate.run(function(){return lease.runWithLeaseId(function(leaseId){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,new Promise(function(resolve,reject){serviceClient.tryRLock({leaseId:leaseId,tenantId:tenantId,resource:resource},function(error,response){if(error){reject(error);return}locked=response.locked;resolve()})})]})})()})})];case 2:_state.sent();return[3,4];case 3:error=_state.sent();lockTracker.rUnlock(tenantId,resource);throw error;case 4:if(!locked){lockTracker.rUnlock(tenantId,resource);return[2,false]}return[4,lease.track(tenantId,resource,true)];case 5:_state.sent();return[2,true]}})})()};
|
package/dist/client/unlock.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ServiceClient } from "@fraym/proto/dist/index.freym.sync.management";
|
|
2
2
|
import { Lease } from "./lease";
|
|
3
|
+
import { LockTracker } from "./lockTracker";
|
|
3
4
|
import { RequestGate } from "./requestGate";
|
|
4
|
-
export declare const unlock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate) => Promise<void>;
|
|
5
|
+
export declare const unlock: (lease: Lease, tenantId: string, resource: string[], serviceClient: ServiceClient, requestGate: RequestGate, lockTracker: LockTracker) => Promise<void>;
|
package/dist/client/unlock.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"unlock",{enumerable:true,get:function(){return unlock}});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:true});Object.defineProperty(exports,"unlock",{enumerable:true,get:function(){return unlock}});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 _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),d=Object.defineProperty;return d(g,"next",{value:verb(0)}),d(g,"throw",{value:verb(1)}),d(g,"return",{value:verb(2)}),typeof Symbol==="function"&&d(g,Symbol.iterator,{value: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 unlock=function unlock(lease,tenantId,resource,serviceClient,requestGate,lockTracker){return _async_to_generator(function(){return _ts_generator(this,function(_state){switch(_state.label){case 0:return[4,requestGate.run(function(){return lease.runWithLeaseId(function(leaseId){return _async_to_generator(function(){return _ts_generator(this,function(_state){return[2,new Promise(function(resolve,reject){serviceClient.unlock({leaseId:leaseId,tenantId:tenantId,resource:resource},function(error){if(error){reject(error);return}resolve()})})]})})()})})];case 1:_state.sent();lockTracker.unlock(tenantId,resource);return[4,lease.untrack(tenantId,resource,false)];case 2:_state.sent();return[2]}})})()};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@fraym/sync",
|
|
3
|
-
"version": "1.0.0-alpha.
|
|
3
|
+
"version": "1.0.0-alpha.23",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"homepage": "https://github.com/fraym/fraeym",
|
|
6
6
|
"repository": {
|
|
@@ -22,7 +22,7 @@
|
|
|
22
22
|
"node": ">=20"
|
|
23
23
|
},
|
|
24
24
|
"dependencies": {
|
|
25
|
-
"@fraym/proto": "^1.0.0-alpha.
|
|
25
|
+
"@fraym/proto": "^1.0.0-alpha.23",
|
|
26
26
|
"@grpc/grpc-js": "^1.14.3",
|
|
27
27
|
"dotenv": "^17.2.4"
|
|
28
28
|
},
|