rasa-pro 3.12.2.dev4__py3-none-any.whl → 3.12.4__py3-none-any.whl
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.
Potentially problematic release.
This version of rasa-pro might be problematic. Click here for more details.
- rasa/core/actions/action.py +28 -38
- rasa/core/actions/action_run_slot_rejections.py +1 -1
- rasa/core/brokers/kafka.py +59 -20
- rasa/core/channels/development_inspector.py +4 -2
- rasa/core/channels/inspector/dist/assets/{arc-9f1365dc.js → arc-c7691751.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{blockDiagram-38ab4fdb-e0f81b12.js → blockDiagram-38ab4fdb-ab99dff7.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{c4Diagram-3d4e48cf-9deaee1c.js → c4Diagram-3d4e48cf-08c35a6b.js} +1 -1
- rasa/core/channels/inspector/dist/assets/channel-11268142.js +1 -0
- rasa/core/channels/inspector/dist/assets/{classDiagram-70f12bd4-20450a96.js → classDiagram-70f12bd4-9e9c71c9.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{classDiagram-v2-f2320105-749d2abf.js → classDiagram-v2-f2320105-15e7e2bf.js} +1 -1
- rasa/core/channels/inspector/dist/assets/clone-ff7f2ce7.js +1 -0
- rasa/core/channels/inspector/dist/assets/{createText-2e5e7dd3-bef0b38c.js → createText-2e5e7dd3-9c105cb1.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{edges-e0da2a9e-943801a7.js → edges-e0da2a9e-77e89e48.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{erDiagram-9861fffd-d523a948.js → erDiagram-9861fffd-7a011646.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDb-956e92f1-54e4cf19.js → flowDb-956e92f1-b6f105ac.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{flowDiagram-66a62f08-48bfbbe8.js → flowDiagram-66a62f08-ce4f18c2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-cba7ae20.js +1 -0
- rasa/core/channels/inspector/dist/assets/{flowchart-elk-definition-4a651766-17c30827.js → flowchart-elk-definition-4a651766-cb5f6da4.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{ganttDiagram-c361ad54-43086f2d.js → ganttDiagram-c361ad54-e4d19e28.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{gitGraphDiagram-72cf32ee-5c8b693e.js → gitGraphDiagram-72cf32ee-727b1c33.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{graph-41a90d26.js → graph-6e2ab9a7.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{index-e8affe45.js → index-098a1a24.js} +3 -3
- rasa/core/channels/inspector/dist/assets/{index-3862675e-b43eeae9.js → index-3862675e-84ec700f.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{infoDiagram-f8f76790-0b20676b.js → infoDiagram-f8f76790-78dda442.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{journeyDiagram-49397b02-39bce7b5.js → journeyDiagram-49397b02-f1cc6dd1.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{layout-dc8eeea4.js → layout-d98dcd0c.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{line-c4d2e756.js → line-838e3d82.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{linear-86f6f2d9.js → linear-eae72406.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{mindmap-definition-fc14e90a-4216f771.js → mindmap-definition-fc14e90a-c96fd84b.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{pieDiagram-8a3498a8-1a0cfa96.js → pieDiagram-8a3498a8-c936d4e2.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{quadrantDiagram-120e2f19-f91e67cf.js → quadrantDiagram-120e2f19-b338eb8f.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{requirementDiagram-deff3bca-d4046bed.js → requirementDiagram-deff3bca-c6b6c0d5.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sankeyDiagram-04a897e0-2cf6d1d7.js → sankeyDiagram-04a897e0-b9372e19.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{sequenceDiagram-704730f1-751ac4f5.js → sequenceDiagram-704730f1-479e0a3f.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-587899a1-f734f4d4.js → stateDiagram-587899a1-fd26eebc.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{stateDiagram-v2-d93cdb3a-91c65710.js → stateDiagram-v2-d93cdb3a-3233e0ae.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-6aaf32cf-e0cff7be.js → styles-6aaf32cf-1fdd392b.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-9a916d00-c8029e5d.js → styles-9a916d00-6d7bfa1b.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{styles-c10674c1-114f312a.js → styles-c10674c1-f86aab11.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{svgDrawCommon-08f97a94-b7b9dc00.js → svgDrawCommon-08f97a94-e3e49d7a.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{timeline-definition-85554ec2-9536d189.js → timeline-definition-85554ec2-6fe08b4d.js} +1 -1
- rasa/core/channels/inspector/dist/assets/{xychartDiagram-e933f94c-bf3b0f36.js → xychartDiagram-e933f94c-c2e06fd6.js} +1 -1
- rasa/core/channels/inspector/dist/index.html +1 -1
- rasa/core/channels/inspector/src/helpers/utils.ts +4 -0
- rasa/core/channels/studio_chat.py +43 -16
- rasa/core/nlg/contextual_response_rephraser.py +6 -7
- rasa/core/nlg/generator.py +21 -5
- rasa/core/nlg/response.py +43 -6
- rasa/core/nlg/translate.py +8 -0
- rasa/model_manager/model_api.py +1 -1
- rasa/model_manager/socket_bridge.py +7 -0
- rasa/shared/core/constants.py +2 -0
- rasa/shared/core/events.py +67 -0
- rasa/shared/core/slots.py +1 -1
- rasa/shared/core/trackers.py +10 -4
- rasa/shared/utils/schemas/events.py +2 -2
- rasa/version.py +1 -1
- {rasa_pro-3.12.2.dev4.dist-info → rasa_pro-3.12.4.dist-info}/METADATA +6 -7
- {rasa_pro-3.12.2.dev4.dist-info → rasa_pro-3.12.4.dist-info}/RECORD +62 -62
- rasa/core/channels/inspector/dist/assets/channel-44956714.js +0 -1
- rasa/core/channels/inspector/dist/assets/clone-a9475142.js +0 -1
- rasa/core/channels/inspector/dist/assets/flowDiagram-v2-96b9c2cf-43fa749a.js +0 -1
- {rasa_pro-3.12.2.dev4.dist-info → rasa_pro-3.12.4.dist-info}/NOTICE +0 -0
- {rasa_pro-3.12.2.dev4.dist-info → rasa_pro-3.12.4.dist-info}/WHEEL +0 -0
- {rasa_pro-3.12.2.dev4.dist-info → rasa_pro-3.12.4.dist-info}/entry_points.txt +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{Z as zt,_ as ot,X as wt,W as Ft,s as Nt,g as Xt,C as Yt,D as St,a as Ht,b as $t,E as Ut,l as Ct,U as qt,i as jt,d as Gt}from"./index-
|
|
1
|
+
import{Z as zt,_ as ot,X as wt,W as Ft,s as Nt,g as Xt,C as Yt,D as St,a as Ht,b as $t,E as Ut,l as Ct,U as qt,i as jt,d as Gt}from"./index-098a1a24.js";import{c as Qt}from"./createText-2e5e7dd3-9c105cb1.js";import{i as Kt}from"./init-77b53fdd.js";import{o as Zt}from"./ordinal-ba9b4969.js";import{l as ft}from"./linear-eae72406.js";import{l as pt}from"./line-838e3d82.js";import"./array-9f3ba611.js";import"./path-53f90ab3.js";function Jt(e,t,i){e=+e,t=+t,i=(n=arguments.length)<2?(t=e,e=0,1):n<3?1:+i;for(var s=-1,n=Math.max(0,Math.ceil((t-e)/i))|0,o=new Array(n);++s<n;)o[s]=e+s*i;return o}function st(){var e=Zt().unknown(void 0),t=e.domain,i=e.range,s=0,n=1,o,c,f=!1,d=0,R=0,_=.5;delete e.unknown;function A(){var m=t().length,T=n<s,S=T?n:s,P=T?s:n;o=(P-S)/Math.max(1,m-d+R*2),f&&(o=Math.floor(o)),S+=(P-S-o*(m-d))*_,c=o*(1-d),f&&(S=Math.round(S),c=Math.round(c));var p=Jt(m).map(function(C){return S+o*C});return i(T?p.reverse():p)}return e.domain=function(m){return arguments.length?(t(m),A()):t()},e.range=function(m){return arguments.length?([s,n]=m,s=+s,n=+n,A()):[s,n]},e.rangeRound=function(m){return[s,n]=m,s=+s,n=+n,f=!0,A()},e.bandwidth=function(){return c},e.step=function(){return o},e.round=function(m){return arguments.length?(f=!!m,A()):f},e.padding=function(m){return arguments.length?(d=Math.min(1,R=+m),A()):d},e.paddingInner=function(m){return arguments.length?(d=Math.min(1,m),A()):d},e.paddingOuter=function(m){return arguments.length?(R=+m,A()):R},e.align=function(m){return arguments.length?(_=Math.max(0,Math.min(1,m)),A()):_},e.copy=function(){return st(t(),[s,n]).round(f).paddingInner(d).paddingOuter(R).align(_)},Kt.apply(A(),arguments)}var nt=function(){var e=function(V,r,l,u){for(l=l||{},u=V.length;u--;l[V[u]]=r);return l},t=[1,10,12,14,16,18,19,21,23],i=[2,6],s=[1,3],n=[1,5],o=[1,6],c=[1,7],f=[1,5,10,12,14,16,18,19,21,23,34,35,36],d=[1,25],R=[1,26],_=[1,28],A=[1,29],m=[1,30],T=[1,31],S=[1,32],P=[1,33],p=[1,34],C=[1,35],h=[1,36],L=[1,37],z=[1,43],lt=[1,42],ct=[1,47],$=[1,50],w=[1,10,12,14,16,18,19,21,23,34,35,36],Q=[1,10,12,14,16,18,19,21,23,24,26,27,28,34,35,36],E=[1,10,12,14,16,18,19,21,23,24,26,27,28,34,35,36,41,42,43,44,45,46,47,48,49,50],ut=[1,64],K={trace:function(){},yy:{},symbols_:{error:2,start:3,eol:4,XYCHART:5,chartConfig:6,document:7,CHART_ORIENTATION:8,statement:9,title:10,text:11,X_AXIS:12,parseXAxis:13,Y_AXIS:14,parseYAxis:15,LINE:16,plotData:17,BAR:18,acc_title:19,acc_title_value:20,acc_descr:21,acc_descr_value:22,acc_descr_multiline_value:23,SQUARE_BRACES_START:24,commaSeparatedNumbers:25,SQUARE_BRACES_END:26,NUMBER_WITH_DECIMAL:27,COMMA:28,xAxisData:29,bandData:30,ARROW_DELIMITER:31,commaSeparatedTexts:32,yAxisData:33,NEWLINE:34,SEMI:35,EOF:36,alphaNum:37,STR:38,MD_STR:39,alphaNumToken:40,AMP:41,NUM:42,ALPHA:43,PLUS:44,EQUALS:45,MULT:46,DOT:47,BRKT:48,MINUS:49,UNDERSCORE:50,$accept:0,$end:1},terminals_:{2:"error",5:"XYCHART",8:"CHART_ORIENTATION",10:"title",12:"X_AXIS",14:"Y_AXIS",16:"LINE",18:"BAR",19:"acc_title",20:"acc_title_value",21:"acc_descr",22:"acc_descr_value",23:"acc_descr_multiline_value",24:"SQUARE_BRACES_START",26:"SQUARE_BRACES_END",27:"NUMBER_WITH_DECIMAL",28:"COMMA",31:"ARROW_DELIMITER",34:"NEWLINE",35:"SEMI",36:"EOF",38:"STR",39:"MD_STR",41:"AMP",42:"NUM",43:"ALPHA",44:"PLUS",45:"EQUALS",46:"MULT",47:"DOT",48:"BRKT",49:"MINUS",50:"UNDERSCORE"},productions_:[0,[3,2],[3,3],[3,2],[3,1],[6,1],[7,0],[7,2],[9,2],[9,2],[9,2],[9,2],[9,2],[9,3],[9,2],[9,3],[9,2],[9,2],[9,1],[17,3],[25,3],[25,1],[13,1],[13,2],[13,1],[29,1],[29,3],[30,3],[32,3],[32,1],[15,1],[15,2],[15,1],[33,3],[4,1],[4,1],[4,1],[11,1],[11,1],[11,1],[37,1],[37,2],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1],[40,1]],performAction:function(r,l,u,g,b,a,F){var x=a.length-1;switch(b){case 5:g.setOrientation(a[x]);break;case 9:g.setDiagramTitle(a[x].text.trim());break;case 12:g.setLineData({text:"",type:"text"},a[x]);break;case 13:g.setLineData(a[x-1],a[x]);break;case 14:g.setBarData({text:"",type:"text"},a[x]);break;case 15:g.setBarData(a[x-1],a[x]);break;case 16:this.$=a[x].trim(),g.setAccTitle(this.$);break;case 17:case 18:this.$=a[x].trim(),g.setAccDescription(this.$);break;case 19:this.$=a[x-1];break;case 20:this.$=[Number(a[x-2]),...a[x]];break;case 21:this.$=[Number(a[x])];break;case 22:g.setXAxisTitle(a[x]);break;case 23:g.setXAxisTitle(a[x-1]);break;case 24:g.setXAxisTitle({type:"text",text:""});break;case 25:g.setXAxisBand(a[x]);break;case 26:g.setXAxisRangeData(Number(a[x-2]),Number(a[x]));break;case 27:this.$=a[x-1];break;case 28:this.$=[a[x-2],...a[x]];break;case 29:this.$=[a[x]];break;case 30:g.setYAxisTitle(a[x]);break;case 31:g.setYAxisTitle(a[x-1]);break;case 32:g.setYAxisTitle({type:"text",text:""});break;case 33:g.setYAxisRangeData(Number(a[x-2]),Number(a[x]));break;case 37:this.$={text:a[x],type:"text"};break;case 38:this.$={text:a[x],type:"text"};break;case 39:this.$={text:a[x],type:"markdown"};break;case 40:this.$=a[x];break;case 41:this.$=a[x-1]+""+a[x];break}},table:[e(t,i,{3:1,4:2,7:4,5:s,34:n,35:o,36:c}),{1:[3]},e(t,i,{4:2,7:4,3:8,5:s,34:n,35:o,36:c}),e(t,i,{4:2,7:4,6:9,3:10,5:s,8:[1,11],34:n,35:o,36:c}),{1:[2,4],9:12,10:[1,13],12:[1,14],14:[1,15],16:[1,16],18:[1,17],19:[1,18],21:[1,19],23:[1,20]},e(f,[2,34]),e(f,[2,35]),e(f,[2,36]),{1:[2,1]},e(t,i,{4:2,7:4,3:21,5:s,34:n,35:o,36:c}),{1:[2,3]},e(f,[2,5]),e(t,[2,7],{4:22,34:n,35:o,36:c}),{11:23,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},{11:39,13:38,24:z,27:lt,29:40,30:41,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},{11:45,15:44,27:ct,33:46,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},{11:49,17:48,24:$,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},{11:52,17:51,24:$,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},{20:[1,53]},{22:[1,54]},e(w,[2,18]),{1:[2,2]},e(w,[2,8]),e(w,[2,9]),e(Q,[2,37],{40:55,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L}),e(Q,[2,38]),e(Q,[2,39]),e(E,[2,40]),e(E,[2,42]),e(E,[2,43]),e(E,[2,44]),e(E,[2,45]),e(E,[2,46]),e(E,[2,47]),e(E,[2,48]),e(E,[2,49]),e(E,[2,50]),e(E,[2,51]),e(w,[2,10]),e(w,[2,22],{30:41,29:56,24:z,27:lt}),e(w,[2,24]),e(w,[2,25]),{31:[1,57]},{11:59,32:58,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},e(w,[2,11]),e(w,[2,30],{33:60,27:ct}),e(w,[2,32]),{31:[1,61]},e(w,[2,12]),{17:62,24:$},{25:63,27:ut},e(w,[2,14]),{17:65,24:$},e(w,[2,16]),e(w,[2,17]),e(E,[2,41]),e(w,[2,23]),{27:[1,66]},{26:[1,67]},{26:[2,29],28:[1,68]},e(w,[2,31]),{27:[1,69]},e(w,[2,13]),{26:[1,70]},{26:[2,21],28:[1,71]},e(w,[2,15]),e(w,[2,26]),e(w,[2,27]),{11:59,32:72,37:24,38:d,39:R,40:27,41:_,42:A,43:m,44:T,45:S,46:P,47:p,48:C,49:h,50:L},e(w,[2,33]),e(w,[2,19]),{25:73,27:ut},{26:[2,28]},{26:[2,20]}],defaultActions:{8:[2,1],10:[2,3],21:[2,2],72:[2,28],73:[2,20]},parseError:function(r,l){if(l.recoverable)this.trace(r);else{var u=new Error(r);throw u.hash=l,u}},parse:function(r){var l=this,u=[0],g=[],b=[null],a=[],F=this.table,x="",U=0,gt=0,Vt=2,xt=1,Wt=a.slice.call(arguments,1),k=Object.create(this.lexer),W={yy:{}};for(var J in this.yy)Object.prototype.hasOwnProperty.call(this.yy,J)&&(W.yy[J]=this.yy[J]);k.setInput(r,W.yy),W.yy.lexer=k,W.yy.parser=this,typeof k.yylloc>"u"&&(k.yylloc={});var tt=k.yylloc;a.push(tt);var Bt=k.options&&k.options.ranges;typeof W.yy.parseError=="function"?this.parseError=W.yy.parseError:this.parseError=Object.getPrototypeOf(this).parseError;function Ot(){var I;return I=g.pop()||k.lex()||xt,typeof I!="number"&&(I instanceof Array&&(g=I,I=g.pop()),I=l.symbols_[I]||I),I}for(var D,B,v,it,O={},q,M,dt,j;;){if(B=u[u.length-1],this.defaultActions[B]?v=this.defaultActions[B]:((D===null||typeof D>"u")&&(D=Ot()),v=F[B]&&F[B][D]),typeof v>"u"||!v.length||!v[0]){var et="";j=[];for(q in F[B])this.terminals_[q]&&q>Vt&&j.push("'"+this.terminals_[q]+"'");k.showPosition?et="Parse error on line "+(U+1)+`:
|
|
2
2
|
`+k.showPosition()+`
|
|
3
3
|
Expecting `+j.join(", ")+", got '"+(this.terminals_[D]||D)+"'":et="Parse error on line "+(U+1)+": Unexpected "+(D==xt?"end of input":"'"+(this.terminals_[D]||D)+"'"),this.parseError(et,{text:k.match,token:this.terminals_[D]||D,line:k.yylineno,loc:tt,expected:j})}if(v[0]instanceof Array&&v.length>1)throw new Error("Parse Error: multiple actions possible at state: "+B+", token: "+D);switch(v[0]){case 1:u.push(D),b.push(k.yytext),a.push(k.yylloc),u.push(v[1]),D=null,gt=k.yyleng,x=k.yytext,U=k.yylineno,tt=k.yylloc;break;case 2:if(M=this.productions_[v[1]][1],O.$=b[b.length-M],O._$={first_line:a[a.length-(M||1)].first_line,last_line:a[a.length-1].last_line,first_column:a[a.length-(M||1)].first_column,last_column:a[a.length-1].last_column},Bt&&(O._$.range=[a[a.length-(M||1)].range[0],a[a.length-1].range[1]]),it=this.performAction.apply(O,[x,gt,U,W.yy,v[1],b,a].concat(Wt)),typeof it<"u")return it;M&&(u=u.slice(0,-1*M*2),b=b.slice(0,-1*M),a=a.slice(0,-1*M)),u.push(this.productions_[v[1]][0]),b.push(O.$),a.push(O._$),dt=F[u[u.length-2]][u[u.length-1]],u.push(dt);break;case 3:return!0}}return!0}},It=function(){var V={EOF:1,parseError:function(l,u){if(this.yy.parser)this.yy.parser.parseError(l,u);else throw new Error(l)},setInput:function(r,l){return this.yy=l||this.yy||{},this._input=r,this._more=this._backtrack=this.done=!1,this.yylineno=this.yyleng=0,this.yytext=this.matched=this.match="",this.conditionStack=["INITIAL"],this.yylloc={first_line:1,first_column:0,last_line:1,last_column:0},this.options.ranges&&(this.yylloc.range=[0,0]),this.offset=0,this},input:function(){var r=this._input[0];this.yytext+=r,this.yyleng++,this.offset++,this.match+=r,this.matched+=r;var l=r.match(/(?:\r\n?|\n).*/g);return l?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),r},unput:function(r){var l=r.length,u=r.split(/(?:\r\n?|\n)/g);this._input=r+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-l),this.offset-=l;var g=this.match.split(/(?:\r\n?|\n)/g);this.match=this.match.substr(0,this.match.length-1),this.matched=this.matched.substr(0,this.matched.length-1),u.length-1&&(this.yylineno-=u.length-1);var b=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:u?(u.length===g.length?this.yylloc.first_column:0)+g[g.length-u.length].length-u[0].length:this.yylloc.first_column-l},this.options.ranges&&(this.yylloc.range=[b[0],b[0]+this.yyleng-l]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},reject:function(){if(this.options.backtrack_lexer)this._backtrack=!0;else return this.parseError("Lexical error on line "+(this.yylineno+1)+`. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).
|
|
4
4
|
`+this.showPosition(),{text:"",token:null,line:this.yylineno});return this},less:function(r){this.unput(this.match.slice(r))},pastInput:function(){var r=this.matched.substr(0,this.matched.length-this.match.length);return(r.length>20?"...":"")+r.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var r=this.match;return r.length<20&&(r+=this._input.substr(0,20-r.length)),(r.substr(0,20)+(r.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var r=this.pastInput(),l=new Array(r.length+1).join("-");return r+this.upcomingInput()+`
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
7
7
|
<link rel="icon" href="" sizes="32x32">
|
|
8
8
|
<title>Rasa inspector</title>
|
|
9
|
-
<script type="module" crossorigin src="./assets/index-
|
|
9
|
+
<script type="module" crossorigin src="./assets/index-098a1a24.js"></script>
|
|
10
10
|
<link rel="stylesheet" href="./assets/index-3ee28881.css">
|
|
11
11
|
</head>
|
|
12
12
|
|
|
@@ -2,6 +2,10 @@ import { SelectedStack, Stack, Event } from "../types";
|
|
|
2
2
|
import { immutableJSONPatch} from 'immutable-json-patch'
|
|
3
3
|
|
|
4
4
|
export const shouldShowTooltip = (text: string) => {
|
|
5
|
+
if (!text) {
|
|
6
|
+
return false;
|
|
7
|
+
}
|
|
8
|
+
|
|
5
9
|
const textLength = text.length;
|
|
6
10
|
|
|
7
11
|
if (textLength > 10 && textLength < 89) {
|
|
@@ -120,6 +120,13 @@ class StudioChatInput(SocketIOInput):
|
|
|
120
120
|
|
|
121
121
|
self._register_tracker_update_hook()
|
|
122
122
|
|
|
123
|
+
async def emit(self, event: str, data: Dict, room: str) -> None:
|
|
124
|
+
"""Emits an event to the websocket."""
|
|
125
|
+
if not self.sio:
|
|
126
|
+
structlogger.error("studio_chat.emit.sio_not_initialized")
|
|
127
|
+
return
|
|
128
|
+
await self.sio.emit(event, data, room=room)
|
|
129
|
+
|
|
123
130
|
def _register_tracker_update_hook(self) -> None:
|
|
124
131
|
plugin_manager().register(StudioTrackerUpdatePlugin(self))
|
|
125
132
|
|
|
@@ -129,10 +136,7 @@ class StudioChatInput(SocketIOInput):
|
|
|
129
136
|
|
|
130
137
|
async def publish_tracker_update(self, sender_id: str, tracker_dump: Dict) -> None:
|
|
131
138
|
"""Publishes a tracker update notification to the websocket."""
|
|
132
|
-
|
|
133
|
-
structlogger.error("studio_chat.on_tracker_updated.sio_not_initialized")
|
|
134
|
-
return
|
|
135
|
-
await self.sio.emit("tracker", tracker_dump, room=sender_id)
|
|
139
|
+
await self.emit("tracker", tracker_dump, room=sender_id)
|
|
136
140
|
|
|
137
141
|
async def on_message_proxy(
|
|
138
142
|
self,
|
|
@@ -172,22 +176,45 @@ class StudioChatInput(SocketIOInput):
|
|
|
172
176
|
structlogger.error("studio_chat.sio.domain_not_initialized")
|
|
173
177
|
return None
|
|
174
178
|
|
|
175
|
-
|
|
176
|
-
tracker = DialogueStateTracker.from_dict(
|
|
177
|
-
data["sender_id"], data["events"], domain.slots
|
|
178
|
-
)
|
|
179
|
-
|
|
180
|
-
# will override an existing tracker with the same id!
|
|
181
|
-
await self.agent.tracker_store.save(tracker)
|
|
179
|
+
tracker: Optional[DialogueStateTracker] = None
|
|
182
180
|
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
181
|
+
async with self.agent.lock_store.lock(data["sender_id"]):
|
|
182
|
+
try:
|
|
183
|
+
tracker = DialogueStateTracker.from_dict(
|
|
184
|
+
data["sender_id"], data["events"], domain.slots
|
|
185
|
+
)
|
|
186
186
|
|
|
187
|
-
|
|
188
|
-
await processor.run_anonymization_pipeline(tracker)
|
|
187
|
+
# will override an existing tracker with the same id!
|
|
189
188
|
await self.agent.tracker_store.save(tracker)
|
|
190
189
|
|
|
190
|
+
processor = self.agent.processor
|
|
191
|
+
if processor and does_need_action_prediction(tracker):
|
|
192
|
+
output_channel = self.get_output_channel()
|
|
193
|
+
|
|
194
|
+
await processor._run_prediction_loop(output_channel, tracker)
|
|
195
|
+
await processor.run_anonymization_pipeline(tracker)
|
|
196
|
+
await self.agent.tracker_store.save(tracker)
|
|
197
|
+
except Exception as e:
|
|
198
|
+
structlogger.error(
|
|
199
|
+
"studio_chat.sio.handle_tracker_update.error",
|
|
200
|
+
error=e,
|
|
201
|
+
sender_id=data["sender_id"],
|
|
202
|
+
)
|
|
203
|
+
await self.emit(
|
|
204
|
+
"error",
|
|
205
|
+
{
|
|
206
|
+
"message": "An error occurred while updating the conversation.",
|
|
207
|
+
"error": str(e),
|
|
208
|
+
"exception": str(type(e).__name__),
|
|
209
|
+
},
|
|
210
|
+
room=sid,
|
|
211
|
+
)
|
|
212
|
+
if not tracker:
|
|
213
|
+
# in case the tracker couldn't be updated, we retrieve the prior
|
|
214
|
+
# version and use that to populate the update
|
|
215
|
+
tracker = await self.agent.tracker_store.get_or_create_tracker(
|
|
216
|
+
data["sender_id"]
|
|
217
|
+
)
|
|
191
218
|
await self.on_tracker_updated(tracker)
|
|
192
219
|
|
|
193
220
|
def blueprint(
|
|
@@ -200,8 +200,10 @@ class ContextualResponseRephraser(
|
|
|
200
200
|
|
|
201
201
|
@measure_llm_latency
|
|
202
202
|
async def _generate_llm_response(self, prompt: str) -> Optional[LLMResponse]:
|
|
203
|
-
"""Use LLM to generate a response
|
|
204
|
-
|
|
203
|
+
"""Use LLM to generate a response.
|
|
204
|
+
|
|
205
|
+
Returns an LLMResponse object containing both the generated text
|
|
206
|
+
(choices) and metadata.
|
|
205
207
|
|
|
206
208
|
Args:
|
|
207
209
|
prompt: The prompt to send to the LLM.
|
|
@@ -367,12 +369,9 @@ class ContextualResponseRephraser(
|
|
|
367
369
|
Returns:
|
|
368
370
|
The generated response.
|
|
369
371
|
"""
|
|
370
|
-
|
|
371
|
-
stack_context = tracker.stack.current_context()
|
|
372
|
-
templated_response = self.generate_from_slots(
|
|
372
|
+
templated_response = await super().generate(
|
|
373
373
|
utter_action=utter_action,
|
|
374
|
-
|
|
375
|
-
stack_context=stack_context,
|
|
374
|
+
tracker=tracker,
|
|
376
375
|
output_channel=output_channel,
|
|
377
376
|
**kwargs,
|
|
378
377
|
)
|
rasa/core/nlg/generator.py
CHANGED
|
@@ -6,6 +6,8 @@ from pypred import Predicate
|
|
|
6
6
|
|
|
7
7
|
import rasa.shared.utils.common
|
|
8
8
|
import rasa.shared.utils.io
|
|
9
|
+
from rasa.core.nlg.translate import has_translation
|
|
10
|
+
from rasa.engine.language import Language
|
|
9
11
|
from rasa.shared.constants import CHANNEL, RESPONSE_CONDITION
|
|
10
12
|
from rasa.shared.core.domain import Domain
|
|
11
13
|
from rasa.shared.core.trackers import DialogueStateTracker
|
|
@@ -131,11 +133,23 @@ class ResponseVariationFilter:
|
|
|
131
133
|
|
|
132
134
|
return True
|
|
133
135
|
|
|
136
|
+
def _filter_by_language(
|
|
137
|
+
self, responses: List[Dict[Text, Any]], language: Optional[Language] = None
|
|
138
|
+
) -> List[Dict[Text, Any]]:
|
|
139
|
+
if not language:
|
|
140
|
+
return responses
|
|
141
|
+
|
|
142
|
+
if filtered := [r for r in responses if has_translation(r, language)]:
|
|
143
|
+
return filtered
|
|
144
|
+
# if no translation is found, return the original response variations
|
|
145
|
+
return responses
|
|
146
|
+
|
|
134
147
|
def responses_for_utter_action(
|
|
135
148
|
self,
|
|
136
149
|
utter_action: Text,
|
|
137
150
|
output_channel: Text,
|
|
138
151
|
filled_slots: Dict[Text, Any],
|
|
152
|
+
language: Optional[Language] = None,
|
|
139
153
|
) -> List[Dict[Text, Any]]:
|
|
140
154
|
"""Returns array of responses that fit the channel, action and condition."""
|
|
141
155
|
# filter responses without a condition
|
|
@@ -176,16 +190,16 @@ class ResponseVariationFilter:
|
|
|
176
190
|
)
|
|
177
191
|
|
|
178
192
|
if conditional_channel:
|
|
179
|
-
return conditional_channel
|
|
193
|
+
return self._filter_by_language(conditional_channel, language)
|
|
180
194
|
|
|
181
195
|
if default_channel:
|
|
182
|
-
return default_channel
|
|
196
|
+
return self._filter_by_language(default_channel, language)
|
|
183
197
|
|
|
184
198
|
if conditional_no_channel:
|
|
185
|
-
return conditional_no_channel
|
|
199
|
+
return self._filter_by_language(conditional_no_channel, language)
|
|
186
200
|
|
|
187
201
|
if default_no_channel:
|
|
188
|
-
return default_no_channel
|
|
202
|
+
return self._filter_by_language(default_no_channel, language)
|
|
189
203
|
|
|
190
204
|
# if there is no response variation selected,
|
|
191
205
|
# return the internal error response to prevent
|
|
@@ -198,7 +212,9 @@ class ResponseVariationFilter:
|
|
|
198
212
|
f"a default variation and that all the conditions are valid. "
|
|
199
213
|
f"Returning the internal error response.",
|
|
200
214
|
)
|
|
201
|
-
return self.
|
|
215
|
+
return self._filter_by_language(
|
|
216
|
+
self.responses.get("utter_internal_error_rasa", []), language
|
|
217
|
+
)
|
|
202
218
|
|
|
203
219
|
def get_response_variation_id(
|
|
204
220
|
self,
|
rasa/core/nlg/response.py
CHANGED
|
@@ -5,8 +5,11 @@ from typing import Any, Dict, List, Optional, Text
|
|
|
5
5
|
from rasa.core.constants import DEFAULT_TEMPLATE_ENGINE, TEMPLATE_ENGINE_CONFIG_KEY
|
|
6
6
|
from rasa.core.nlg import interpolator
|
|
7
7
|
from rasa.core.nlg.generator import NaturalLanguageGenerator, ResponseVariationFilter
|
|
8
|
-
from rasa.
|
|
8
|
+
from rasa.core.nlg.translate import get_translated_buttons, get_translated_text
|
|
9
|
+
from rasa.engine.language import Language
|
|
10
|
+
from rasa.shared.constants import BUTTONS, RESPONSE_CONDITION, TEXT
|
|
9
11
|
from rasa.shared.core.domain import RESPONSE_KEYS_TO_INTERPOLATE
|
|
12
|
+
from rasa.shared.core.flows.constants import KEY_TRANSLATION
|
|
10
13
|
from rasa.shared.core.trackers import DialogueStateTracker
|
|
11
14
|
from rasa.shared.nlu.constants import METADATA
|
|
12
15
|
|
|
@@ -30,7 +33,11 @@ class TemplatedNaturalLanguageGenerator(NaturalLanguageGenerator):
|
|
|
30
33
|
|
|
31
34
|
# noinspection PyUnusedLocal
|
|
32
35
|
def _random_response_for(
|
|
33
|
-
self,
|
|
36
|
+
self,
|
|
37
|
+
utter_action: Text,
|
|
38
|
+
output_channel: Text,
|
|
39
|
+
filled_slots: Dict[Text, Any],
|
|
40
|
+
language: Optional[Language] = None,
|
|
34
41
|
) -> Optional[Dict[Text, Any]]:
|
|
35
42
|
"""Select random response for the utter action from available ones.
|
|
36
43
|
|
|
@@ -42,7 +49,7 @@ class TemplatedNaturalLanguageGenerator(NaturalLanguageGenerator):
|
|
|
42
49
|
if utter_action in self.responses:
|
|
43
50
|
response_filter = ResponseVariationFilter(self.responses)
|
|
44
51
|
suitable_responses = response_filter.responses_for_utter_action(
|
|
45
|
-
utter_action, output_channel, filled_slots
|
|
52
|
+
utter_action, output_channel, filled_slots, language
|
|
46
53
|
)
|
|
47
54
|
|
|
48
55
|
if suitable_responses:
|
|
@@ -75,9 +82,36 @@ class TemplatedNaturalLanguageGenerator(NaturalLanguageGenerator):
|
|
|
75
82
|
"""Generate a response for the requested utter action."""
|
|
76
83
|
filled_slots = tracker.current_slot_values()
|
|
77
84
|
stack_context = tracker.stack.current_context()
|
|
78
|
-
|
|
79
|
-
utter_action,
|
|
85
|
+
response = self.generate_from_slots(
|
|
86
|
+
utter_action,
|
|
87
|
+
filled_slots,
|
|
88
|
+
stack_context,
|
|
89
|
+
output_channel,
|
|
90
|
+
tracker.current_language,
|
|
91
|
+
**kwargs,
|
|
80
92
|
)
|
|
93
|
+
if response is not None:
|
|
94
|
+
return self.translate_response(response, tracker.current_language)
|
|
95
|
+
return None
|
|
96
|
+
|
|
97
|
+
def translate_response(
|
|
98
|
+
self, response: Dict[Text, Any], language: Optional[Language] = None
|
|
99
|
+
) -> Dict[Text, Any]:
|
|
100
|
+
message_copy = copy.deepcopy(response)
|
|
101
|
+
|
|
102
|
+
text = get_translated_text(
|
|
103
|
+
text=message_copy.pop(TEXT, None),
|
|
104
|
+
translation=message_copy.pop(KEY_TRANSLATION, {}),
|
|
105
|
+
language=language,
|
|
106
|
+
)
|
|
107
|
+
|
|
108
|
+
buttons = get_translated_buttons(
|
|
109
|
+
buttons=message_copy.pop(BUTTONS, None), language=language
|
|
110
|
+
)
|
|
111
|
+
message_copy[TEXT] = text
|
|
112
|
+
if buttons:
|
|
113
|
+
message_copy[BUTTONS] = buttons
|
|
114
|
+
return message_copy
|
|
81
115
|
|
|
82
116
|
def generate_from_slots(
|
|
83
117
|
self,
|
|
@@ -85,12 +119,15 @@ class TemplatedNaturalLanguageGenerator(NaturalLanguageGenerator):
|
|
|
85
119
|
filled_slots: Dict[Text, Any],
|
|
86
120
|
stack_context: Dict[Text, Any],
|
|
87
121
|
output_channel: Text,
|
|
122
|
+
language: Optional[Language] = None,
|
|
88
123
|
**kwargs: Any,
|
|
89
124
|
) -> Optional[Dict[Text, Any]]:
|
|
90
125
|
"""Generate a response for the requested utter action."""
|
|
91
126
|
# Fetching a random response for the passed utter action
|
|
92
127
|
r = copy.deepcopy(
|
|
93
|
-
self._random_response_for(
|
|
128
|
+
self._random_response_for(
|
|
129
|
+
utter_action, output_channel, filled_slots, language
|
|
130
|
+
)
|
|
94
131
|
)
|
|
95
132
|
# Filling the slots in the response with placeholders and returning the response
|
|
96
133
|
if r is not None:
|
rasa/core/nlg/translate.py
CHANGED
|
@@ -23,6 +23,14 @@ def get_translated_text(
|
|
|
23
23
|
return translation.get(language_code, text)
|
|
24
24
|
|
|
25
25
|
|
|
26
|
+
def has_translation(
|
|
27
|
+
message: Dict[Text, Any], language: Optional[Language] = None
|
|
28
|
+
) -> bool:
|
|
29
|
+
"""Check if the message has a translation for the given language."""
|
|
30
|
+
language_code = language.code if language else None
|
|
31
|
+
return language_code in message.get(KEY_TRANSLATION, {})
|
|
32
|
+
|
|
33
|
+
|
|
26
34
|
def get_translated_buttons(
|
|
27
35
|
buttons: Optional[List[Dict[Text, Any]]], language: Optional[Language] = None
|
|
28
36
|
) -> Optional[List[Dict[Text, Any]]]:
|
rasa/model_manager/model_api.py
CHANGED
|
@@ -483,7 +483,7 @@ def external_blueprint() -> Blueprint:
|
|
|
483
483
|
"""Create a blueprint for the model manager API."""
|
|
484
484
|
from rasa.core.channels.socketio import SocketBlueprint
|
|
485
485
|
|
|
486
|
-
sio = AsyncServer(async_mode="sanic", cors_allowed_origins=
|
|
486
|
+
sio = AsyncServer(async_mode="sanic", cors_allowed_origins="*")
|
|
487
487
|
bp = SocketBlueprint(sio, "", "model_api_external")
|
|
488
488
|
|
|
489
489
|
create_bridge_server(sio, running_bots)
|
|
@@ -131,6 +131,13 @@ async def create_bridge_client(
|
|
|
131
131
|
structlogger.debug("model_runner.bot_message", deployment_id=deployment_id)
|
|
132
132
|
await sio.emit("bot_message", data, room=sid)
|
|
133
133
|
|
|
134
|
+
@client.event # type: ignore[misc]
|
|
135
|
+
async def error(data: Dict[str, Any]) -> None:
|
|
136
|
+
structlogger.debug(
|
|
137
|
+
"model_runner.bot_error", deployment_id=deployment_id, data=data
|
|
138
|
+
)
|
|
139
|
+
await sio.emit("error", data, room=sid)
|
|
140
|
+
|
|
134
141
|
@client.event # type: ignore[misc]
|
|
135
142
|
async def tracker(data: Dict[str, Any]) -> None:
|
|
136
143
|
await sio.emit("tracker", json.loads(data), room=sid)
|
rasa/shared/core/constants.py
CHANGED
rasa/shared/core/events.py
CHANGED
|
@@ -36,6 +36,7 @@ from rasa.shared.core.constants import (
|
|
|
36
36
|
ACTION_NAME_SENDER_ID_CONNECTOR_STR,
|
|
37
37
|
ACTION_SESSION_START_NAME,
|
|
38
38
|
ENTITY_LABEL_SEPARATOR,
|
|
39
|
+
ERROR_CODE_KEY,
|
|
39
40
|
EXTERNAL_MESSAGE_PREFIX,
|
|
40
41
|
IS_EXTERNAL,
|
|
41
42
|
LOOP_INTERRUPTED,
|
|
@@ -2578,3 +2579,69 @@ class SessionEnded(AlwaysEqualEventMixin):
|
|
|
2578
2579
|
"""Applies event to current conversation state."""
|
|
2579
2580
|
# noinspection PyProtectedMember
|
|
2580
2581
|
tracker._reset()
|
|
2582
|
+
|
|
2583
|
+
|
|
2584
|
+
class ErrorHandled(Event):
|
|
2585
|
+
"""An error occurred during the conversation.
|
|
2586
|
+
|
|
2587
|
+
The error message is stored in the metadata of the event.
|
|
2588
|
+
"""
|
|
2589
|
+
|
|
2590
|
+
type_name = "error"
|
|
2591
|
+
|
|
2592
|
+
def __init__(
|
|
2593
|
+
self,
|
|
2594
|
+
error_code: int,
|
|
2595
|
+
timestamp: Optional[float] = None,
|
|
2596
|
+
metadata: Optional[Dict[str, Any]] = None,
|
|
2597
|
+
) -> None:
|
|
2598
|
+
"""Creates event for an error.
|
|
2599
|
+
|
|
2600
|
+
Args:
|
|
2601
|
+
error_code: Error int code.
|
|
2602
|
+
timestamp: When the event was created.
|
|
2603
|
+
metadata: Additional event metadata.
|
|
2604
|
+
"""
|
|
2605
|
+
self.error_code = error_code
|
|
2606
|
+
super().__init__(timestamp, metadata)
|
|
2607
|
+
|
|
2608
|
+
def __str__(self) -> Text:
|
|
2609
|
+
"""Returns text representation of event."""
|
|
2610
|
+
return f"ErrorHandled({self.error_code})"
|
|
2611
|
+
|
|
2612
|
+
def __repr__(self) -> Text:
|
|
2613
|
+
"""Returns event as string for debugging."""
|
|
2614
|
+
return f"ErrorHandled({self.error_code}, {self.timestamp}, {self.metadata})"
|
|
2615
|
+
|
|
2616
|
+
def __hash__(self) -> int:
|
|
2617
|
+
"""Returns unique hash for event."""
|
|
2618
|
+
return hash(self.error_code)
|
|
2619
|
+
|
|
2620
|
+
def __eq__(self, other: Any) -> bool:
|
|
2621
|
+
"""Compares object with other object."""
|
|
2622
|
+
if not isinstance(other, ErrorHandled):
|
|
2623
|
+
return NotImplemented
|
|
2624
|
+
|
|
2625
|
+
return self.error_code == other.error_code
|
|
2626
|
+
|
|
2627
|
+
def as_story_string(self) -> Text:
|
|
2628
|
+
"""Returns text representation of event."""
|
|
2629
|
+
props = json.dumps({ERROR_CODE_KEY: self.error_code})
|
|
2630
|
+
return f"{ErrorHandled.type_name}{props}"
|
|
2631
|
+
|
|
2632
|
+
@classmethod
|
|
2633
|
+
def _from_story_string(cls, parameters: Dict[Text, Any]) -> List["ErrorHandled"]:
|
|
2634
|
+
"""Called to convert a parsed story line into an event."""
|
|
2635
|
+
return [
|
|
2636
|
+
ErrorHandled(
|
|
2637
|
+
parameters.get(ERROR_CODE_KEY),
|
|
2638
|
+
parameters.get("timestamp"),
|
|
2639
|
+
parameters.get("metadata"),
|
|
2640
|
+
)
|
|
2641
|
+
]
|
|
2642
|
+
|
|
2643
|
+
def as_dict(self) -> Dict[Text, Any]:
|
|
2644
|
+
"""Returns serialized event."""
|
|
2645
|
+
serialized = super().as_dict()
|
|
2646
|
+
serialized.update({ERROR_CODE_KEY: self.error_code})
|
|
2647
|
+
return serialized
|
rasa/shared/core/slots.py
CHANGED
|
@@ -787,7 +787,7 @@ class StrictCategoricalSlot(CategoricalSlot):
|
|
|
787
787
|
def coerce_value(self, value: Any) -> Any:
|
|
788
788
|
"""Coerce the value to one of the allowed ones or raise an error if invalid."""
|
|
789
789
|
if value is None:
|
|
790
|
-
return
|
|
790
|
+
return self.initial_value
|
|
791
791
|
|
|
792
792
|
for allowed_value in self.values:
|
|
793
793
|
# Allowed values are always stored as strings, so we can use casefold().
|
rasa/shared/core/trackers.py
CHANGED
|
@@ -1123,10 +1123,16 @@ class DialogueStateTracker:
|
|
|
1123
1123
|
f"Please update the slot configuration accordingly."
|
|
1124
1124
|
)
|
|
1125
1125
|
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1126
|
+
supported_languages = []
|
|
1127
|
+
for language_code in language_slot.values:
|
|
1128
|
+
is_default = language_code == language_slot.initial_value
|
|
1129
|
+
language = Language.from_language_code(
|
|
1130
|
+
language_code=language_code,
|
|
1131
|
+
is_default=is_default,
|
|
1132
|
+
)
|
|
1133
|
+
supported_languages.append(language)
|
|
1134
|
+
|
|
1135
|
+
return supported_languages
|
|
1130
1136
|
|
|
1131
1137
|
@property
|
|
1132
1138
|
def current_language(self) -> Optional[Language]:
|
|
@@ -165,8 +165,7 @@ DIALOGUE_STACK_UPDATED = {
|
|
|
165
165
|
}
|
|
166
166
|
ROUTING_SESSION_ENDED = {"properties": {"event": {"const": "routing_session_ended"}}}
|
|
167
167
|
|
|
168
|
-
|
|
169
|
-
ROUTING_SESSION_ENDED = {"properties": {"event": {"const": "routing_session_ended"}}}
|
|
168
|
+
ERROR_HANDLED = {"properties": {"event": {"const": "error"}}}
|
|
170
169
|
|
|
171
170
|
EVENT_SCHEMA = {
|
|
172
171
|
"type": "object",
|
|
@@ -208,6 +207,7 @@ EVENT_SCHEMA = {
|
|
|
208
207
|
DIALOGUE_STACK_UPDATED,
|
|
209
208
|
ROUTING_SESSION_ENDED,
|
|
210
209
|
SESSION_ENDED,
|
|
210
|
+
ERROR_HANDLED,
|
|
211
211
|
],
|
|
212
212
|
}
|
|
213
213
|
|
rasa/version.py
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: rasa-pro
|
|
3
|
-
Version: 3.12.
|
|
3
|
+
Version: 3.12.4
|
|
4
4
|
Summary: State-of-the-art open-core Conversational AI framework for Enterprises that natively leverages generative AI for effortless assistant development.
|
|
5
5
|
Home-page: https://rasa.com
|
|
6
6
|
Keywords: nlp,machine-learning,machine-learning-library,bot,bots,botkit,rasa conversational-agents,conversational-ai,chatbot,chatbot-framework,bot-framework
|
|
@@ -8,11 +8,10 @@ Author: Rasa Technologies GmbH
|
|
|
8
8
|
Author-email: hi@rasa.com
|
|
9
9
|
Maintainer: Tom Bocklisch
|
|
10
10
|
Maintainer-email: tom@rasa.com
|
|
11
|
-
Requires-Python: >=3.9,<3.12
|
|
11
|
+
Requires-Python: >=3.9.2,<3.12
|
|
12
12
|
Classifier: Development Status :: 5 - Production/Stable
|
|
13
13
|
Classifier: Intended Audience :: Developers
|
|
14
14
|
Classifier: Programming Language :: Python :: 3
|
|
15
|
-
Classifier: Programming Language :: Python :: 3.9
|
|
16
15
|
Classifier: Programming Language :: Python :: 3.10
|
|
17
16
|
Classifier: Programming Language :: Python :: 3.11
|
|
18
17
|
Classifier: Topic :: Software Development :: Libraries
|
|
@@ -40,7 +39,7 @@ Requires-Dist: colorclass (>=2.2,<2.3)
|
|
|
40
39
|
Requires-Dist: coloredlogs (>=15,<16)
|
|
41
40
|
Requires-Dist: colorhash (>=2.0,<2.1.0)
|
|
42
41
|
Requires-Dist: confluent-kafka (>=2.3.0,<3.0.0)
|
|
43
|
-
Requires-Dist: cryptography (>=
|
|
42
|
+
Requires-Dist: cryptography (>=44.0.1)
|
|
44
43
|
Requires-Dist: cvg-python-sdk (>=0.5.1,<0.6.0)
|
|
45
44
|
Requires-Dist: dask (>=2024.7.0,<2024.8.0)
|
|
46
45
|
Requires-Dist: demoji (>=1.1.0,<2.0.0)
|
|
@@ -57,13 +56,13 @@ Requires-Dist: hvac (>=1.2.1,<2.0.0)
|
|
|
57
56
|
Requires-Dist: importlib-metadata (>=8.5.0,<8.6.0)
|
|
58
57
|
Requires-Dist: importlib-resources (==6.1.3)
|
|
59
58
|
Requires-Dist: jieba (>=0.42.1,<0.43) ; extra == "jieba" or extra == "full"
|
|
60
|
-
Requires-Dist: jinja2 (>=3.1.
|
|
59
|
+
Requires-Dist: jinja2 (>=3.1.6,<3.2.0)
|
|
61
60
|
Requires-Dist: jsonpatch (>=1.33,<2.0)
|
|
62
61
|
Requires-Dist: jsonpickle (>=3.3.0,<3.4)
|
|
63
62
|
Requires-Dist: jsonschema (>=4.22)
|
|
64
63
|
Requires-Dist: keras (==2.14.0)
|
|
65
|
-
Requires-Dist: langchain (>=0.2.
|
|
66
|
-
Requires-Dist: langchain-community (>=0.2.
|
|
64
|
+
Requires-Dist: langchain (>=0.2.17,<0.3.0)
|
|
65
|
+
Requires-Dist: langchain-community (>=0.2.19,<0.3.0)
|
|
67
66
|
Requires-Dist: langcodes (>=3.5.0,<4.0.0)
|
|
68
67
|
Requires-Dist: litellm (>=1.52.6,<1.53.0)
|
|
69
68
|
Requires-Dist: matplotlib (>=3.7,<3.8)
|