@splitlab/core 0.1.0 → 0.2.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.
- package/dist/index.cjs +1 -1
- package/dist/index.d.cts +16 -2
- package/dist/index.d.ts +16 -2
- package/dist/index.js +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var h=Object.defineProperty;var k=Object.getOwnPropertyDescriptor;var S=Object.getOwnPropertyNames;var _=Object.prototype.hasOwnProperty;var A=(r,a)=>{for(var t in a)h(r,t,{get:a[t],enumerable:!0})},R=(r,a,t,l)=>{if(a&&typeof a=="object"||typeof a=="function")for(let s of S(a))!_.call(r,s)&&s!==t&&h(r,s,{get:()=>a[s],enumerable:!(l=k(a,s))||l.enumerable});return r};var T=r=>R(h({},"__esModule",{value:!0}),r);var w={};A(w,{evaluateRules:()=>m,hashToFloat:()=>x,localEvaluate:()=>y,murmurhash3:()=>g});module.exports=T(w);function g(r,a=0){let t=a>>>0,l=r.length,s=l>>2,n=3432918353,i=461845907;for(let u=0;u<s;u++){let o=r.charCodeAt(u*4)&255|(r.charCodeAt(u*4+1)&255)<<8|(r.charCodeAt(u*4+2)&255)<<16|(r.charCodeAt(u*4+3)&255)<<24;o=Math.imul(o,n),o=o<<15|o>>>17,o=Math.imul(o,i),t^=o,t=t<<13|t>>>19,t=Math.imul(t,5)+3864292196}let f=s*4,e=0;switch(l&3){case 3:e^=(r.charCodeAt(f+2)&255)<<16;case 2:e^=(r.charCodeAt(f+1)&255)<<8;case 1:e^=r.charCodeAt(f)&255,e=Math.imul(e,n),e=e<<15|e>>>17,e=Math.imul(e,i),t^=e}return t^=l,t^=t>>>16,t=Math.imul(t,2246822507),t^=t>>>13,t=Math.imul(t,3266489909),t^=t>>>16,t>>>0}function x(r,a){return g(r,a)/4294967295}function y(r,a,t={}){let l={},s={},n=r.segments||[],i=r.exclusion_groups||[],f=new Map;for(let e of i)for(let[u,o]of Object.entries(e.experiments))f.set(u,{layer_key:e.layer_key,...o});for(let e of r.experiments){if(e.targeting_rules&&!m(e.targeting_rules,t,n)){l[e.key]=null;continue}let u=f.get(e.key);if(u){let c=g(u.layer_key+":"+a)%1e4;if(c<u.bucket_start||c>=u.bucket_end){l[e.key]=null;continue}}let o=g(e.key+":"+a);if(o%1e4/100>=e.traffic_percentage){l[e.key]=null;continue}let b=e.variants.reduce((c,C)=>c+C.weight,0),d=o%b,v=0,p=null;for(let c of e.variants)if(v+=c.weight,d<v){p=c.key;break}p||(p=e.variants[e.variants.length-1].key),l[e.key]=p}for(let e of r.flags){if(e.rules&&!m(e.rules,t,n)){s[e.key]=!1;continue}let o=g(e.key+":"+a)%100;s[e.key]=o<e.rollout_percentage}return{experiments:l,flags:s}}function m(r,a,t=[]){if(!r.groups||r.groups.length===0)return!0;let l=n=>{if(n.attribute==="$segment"){if(!Array.isArray(n.value))return!1;let f=n.value.map(String);return n.operator==="in"?f.some(e=>{let u=t.find(o=>o.id===e||o.key===e);return u?m(u.rules,a,t):!1}):n.operator==="not_in"?!f.some(e=>{let u=t.find(o=>o.id===e||o.key===e);return u?m(u.rules,a,t):!1}):!1}let i=a[n.attribute];if(i==null)return!1;switch(n.operator){case"is":return String(i)===String(n.value);case"is_not":return String(i)!==String(n.value);case"contains":return String(i).toLowerCase().includes(String(n.value).toLowerCase());case"not_contains":return!String(i).toLowerCase().includes(String(n.value).toLowerCase());case"gt":return Number(i)>Number(n.value);case"lt":return Number(i)<Number(n.value);case"gte":return Number(i)>=Number(n.value);case"lte":return Number(i)<=Number(n.value);case"in":return Array.isArray(n.value)&&n.value.map(String).includes(String(i));case"not_in":return Array.isArray(n.value)&&!n.value.map(String).includes(String(i));default:return!1}},s=n=>n.conditions.every(l);return r.match==="any"?r.groups.some(s):r.groups.every(s)}0&&(module.exports={evaluateRules,hashToFloat,localEvaluate,murmurhash3});
|
package/dist/index.d.cts
CHANGED
|
@@ -37,9 +37,23 @@ interface FlagConfig {
|
|
|
37
37
|
rollout_percentage: number;
|
|
38
38
|
rules?: TargetingRules | null;
|
|
39
39
|
}
|
|
40
|
+
interface SegmentConfig {
|
|
41
|
+
id: string;
|
|
42
|
+
key: string;
|
|
43
|
+
rules: TargetingRules;
|
|
44
|
+
}
|
|
45
|
+
interface ExclusionGroupConfig {
|
|
46
|
+
layer_key: string;
|
|
47
|
+
experiments: Record<string, {
|
|
48
|
+
bucket_start: number;
|
|
49
|
+
bucket_end: number;
|
|
50
|
+
}>;
|
|
51
|
+
}
|
|
40
52
|
interface ServerConfig {
|
|
41
53
|
experiments: ExperimentConfig[];
|
|
42
54
|
flags: FlagConfig[];
|
|
55
|
+
segments?: SegmentConfig[];
|
|
56
|
+
exclusion_groups?: ExclusionGroupConfig[];
|
|
43
57
|
}
|
|
44
58
|
interface EvalResult {
|
|
45
59
|
experiments: Record<string, string | null>;
|
|
@@ -61,6 +75,6 @@ declare function localEvaluate(config: ServerConfig, distinctId: string, attribu
|
|
|
61
75
|
* Evaluate targeting rules against a set of attributes.
|
|
62
76
|
* Returns true if the rules match (user is targeted).
|
|
63
77
|
*/
|
|
64
|
-
declare function evaluateRules(rules: TargetingRules, attributes: Record<string, any
|
|
78
|
+
declare function evaluateRules(rules: TargetingRules, attributes: Record<string, any>, segments?: SegmentConfig[]): boolean;
|
|
65
79
|
|
|
66
|
-
export { type EvalResult, type ExperimentConfig, type FlagConfig, type ServerConfig, type TargetingCondition, type TargetingGroup, type TargetingRules, type TrackEvent, type Variant, evaluateRules, hashToFloat, localEvaluate, murmurhash3 };
|
|
80
|
+
export { type EvalResult, type ExclusionGroupConfig, type ExperimentConfig, type FlagConfig, type SegmentConfig, type ServerConfig, type TargetingCondition, type TargetingGroup, type TargetingRules, type TrackEvent, type Variant, evaluateRules, hashToFloat, localEvaluate, murmurhash3 };
|
package/dist/index.d.ts
CHANGED
|
@@ -37,9 +37,23 @@ interface FlagConfig {
|
|
|
37
37
|
rollout_percentage: number;
|
|
38
38
|
rules?: TargetingRules | null;
|
|
39
39
|
}
|
|
40
|
+
interface SegmentConfig {
|
|
41
|
+
id: string;
|
|
42
|
+
key: string;
|
|
43
|
+
rules: TargetingRules;
|
|
44
|
+
}
|
|
45
|
+
interface ExclusionGroupConfig {
|
|
46
|
+
layer_key: string;
|
|
47
|
+
experiments: Record<string, {
|
|
48
|
+
bucket_start: number;
|
|
49
|
+
bucket_end: number;
|
|
50
|
+
}>;
|
|
51
|
+
}
|
|
40
52
|
interface ServerConfig {
|
|
41
53
|
experiments: ExperimentConfig[];
|
|
42
54
|
flags: FlagConfig[];
|
|
55
|
+
segments?: SegmentConfig[];
|
|
56
|
+
exclusion_groups?: ExclusionGroupConfig[];
|
|
43
57
|
}
|
|
44
58
|
interface EvalResult {
|
|
45
59
|
experiments: Record<string, string | null>;
|
|
@@ -61,6 +75,6 @@ declare function localEvaluate(config: ServerConfig, distinctId: string, attribu
|
|
|
61
75
|
* Evaluate targeting rules against a set of attributes.
|
|
62
76
|
* Returns true if the rules match (user is targeted).
|
|
63
77
|
*/
|
|
64
|
-
declare function evaluateRules(rules: TargetingRules, attributes: Record<string, any
|
|
78
|
+
declare function evaluateRules(rules: TargetingRules, attributes: Record<string, any>, segments?: SegmentConfig[]): boolean;
|
|
65
79
|
|
|
66
|
-
export { type EvalResult, type ExperimentConfig, type FlagConfig, type ServerConfig, type TargetingCondition, type TargetingGroup, type TargetingRules, type TrackEvent, type Variant, evaluateRules, hashToFloat, localEvaluate, murmurhash3 };
|
|
80
|
+
export { type EvalResult, type ExclusionGroupConfig, type ExperimentConfig, type FlagConfig, type SegmentConfig, type ServerConfig, type TargetingCondition, type TargetingGroup, type TargetingRules, type TrackEvent, type Variant, evaluateRules, hashToFloat, localEvaluate, murmurhash3 };
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
function g(n,i=0){let t=i>>>0,
|
|
1
|
+
function g(n,i=0){let t=i>>>0,s=n.length,l=s>>2,r=3432918353,u=461845907;for(let o=0;o<l;o++){let a=n.charCodeAt(o*4)&255|(n.charCodeAt(o*4+1)&255)<<8|(n.charCodeAt(o*4+2)&255)<<16|(n.charCodeAt(o*4+3)&255)<<24;a=Math.imul(a,r),a=a<<15|a>>>17,a=Math.imul(a,u),t^=a,t=t<<13|t>>>19,t=Math.imul(t,5)+3864292196}let f=l*4,e=0;switch(s&3){case 3:e^=(n.charCodeAt(f+2)&255)<<16;case 2:e^=(n.charCodeAt(f+1)&255)<<8;case 1:e^=n.charCodeAt(f)&255,e=Math.imul(e,r),e=e<<15|e>>>17,e=Math.imul(e,u),t^=e}return t^=s,t^=t>>>16,t=Math.imul(t,2246822507),t^=t>>>13,t=Math.imul(t,3266489909),t^=t>>>16,t>>>0}function b(n,i){return g(n,i)/4294967295}function d(n,i,t={}){let s={},l={},r=n.segments||[],u=n.exclusion_groups||[],f=new Map;for(let e of u)for(let[o,a]of Object.entries(e.experiments))f.set(o,{layer_key:e.layer_key,...a});for(let e of n.experiments){if(e.targeting_rules&&!m(e.targeting_rules,t,r)){s[e.key]=null;continue}let o=f.get(e.key);if(o){let c=g(o.layer_key+":"+i)%1e4;if(c<o.bucket_start||c>=o.bucket_end){s[e.key]=null;continue}}let a=g(e.key+":"+i);if(a%1e4/100>=e.traffic_percentage){s[e.key]=null;continue}let v=e.variants.reduce((c,y)=>c+y.weight,0),x=a%v,h=0,p=null;for(let c of e.variants)if(h+=c.weight,x<h){p=c.key;break}p||(p=e.variants[e.variants.length-1].key),s[e.key]=p}for(let e of n.flags){if(e.rules&&!m(e.rules,t,r)){l[e.key]=!1;continue}let a=g(e.key+":"+i)%100;l[e.key]=a<e.rollout_percentage}return{experiments:s,flags:l}}function m(n,i,t=[]){if(!n.groups||n.groups.length===0)return!0;let s=r=>{if(r.attribute==="$segment"){if(!Array.isArray(r.value))return!1;let f=r.value.map(String);return r.operator==="in"?f.some(e=>{let o=t.find(a=>a.id===e||a.key===e);return o?m(o.rules,i,t):!1}):r.operator==="not_in"?!f.some(e=>{let o=t.find(a=>a.id===e||a.key===e);return o?m(o.rules,i,t):!1}):!1}let u=i[r.attribute];if(u==null)return!1;switch(r.operator){case"is":return String(u)===String(r.value);case"is_not":return String(u)!==String(r.value);case"contains":return String(u).toLowerCase().includes(String(r.value).toLowerCase());case"not_contains":return!String(u).toLowerCase().includes(String(r.value).toLowerCase());case"gt":return Number(u)>Number(r.value);case"lt":return Number(u)<Number(r.value);case"gte":return Number(u)>=Number(r.value);case"lte":return Number(u)<=Number(r.value);case"in":return Array.isArray(r.value)&&r.value.map(String).includes(String(u));case"not_in":return Array.isArray(r.value)&&!r.value.map(String).includes(String(u));default:return!1}},l=r=>r.conditions.every(s);return n.match==="any"?n.groups.some(l):n.groups.every(l)}export{m as evaluateRules,b as hashToFloat,d as localEvaluate,g as murmurhash3};
|