Hello, I just tested with:
$avp(s:callfwd) = $ruri; using kamailio.cfg from master branch and all is ok. Have you loaded the pv module? Cheers, Daniel On 06/10/16 00:56, Brian McCrary wrote: > Hello, > > Thanks so much for the help in pointing me in the right direction. I > finally had some time today to work with Kamailio a little. I should > have pointed out I had commented the avp_write line out in the config > file and had attempted to convert it to the new format as you had > suggested. I had $avp(s:callfwd) = $ruri; instead of $avp(callfwd) = > $ruri; but it seems both give the same error. > > With that being said, thanks for pointing out the sqlops module. It > looks like I should be able to make it do everything I need, and then > some. There are some things I have been wanting to improve upon and it > looks like this will certainly help. There has been a lot of really > nice things added to these new releases! I'm going to give that a go > and see if I can fix the error by eliminating the problem altogether. :) > > Thanks, > > Brian > > On Mon, Oct 03, 2016 at 09:00:24PM +0200, Daniel-Constantin Mierla wrote: >> Hello, >> >> hmm, the format $avp(s:callfwd) should still work fine. I will look >> deeper at it when I get a chance after returning to the office in few >> days. Anyhow, try to use $avp(callfwd), it is the same as $avp(callfwd) >> if you haven't defined an overlapping avp-alias. >> >> On the other hand, I think avp_write(...) is no longer available. Now >> you can use direct assignment, like: >> >> $avp(callfwd) = $ruri; >> >> One very useful additions (in newer versions than 1.0, otherwise being >> quite old by now) is the sqlops module that allows to do all kind of sql >> operations from configuration file, in many cases saving from the >> complexity of using avpops db functions. See: >> >> https://www.kamailio.org/docs/modules/stable/modules/sqlops.html#idp44901364 >> >> So you can do INSERT/UPDATE/REPLACE/... as you need from config file, >> building the sql query with the variables you want. >> >> Cheers, >> Daniel >> >> On 30/09/16 18:29, Brian McCrary wrote: >>> Hello group, >>> >>> I know this may be hard to believe but I'm in the process of upgrading >>> an old, but stable, OpenSER 1.0 group of servers to Kamilio. I'm >>> basically going to sort of start from scratch with the database and >>> export my old MySQL database and write some scripts to reimport the data >>> using kamctl scripts since the database structure has changed >>> substantially since then it looks like. >>> >>> I've mostly migrated the config file over fairly easily, except for >>> AVPops. I've got a section of config file that writes into the >>> usr_preferences database for call forwarding, but I seem to get the same >>> error anywhere I try to write to the database using AVPops. Here's the >>> output I get when checking the config: >>> >>> 0(1378) DEBUG: <core> [pvapi.c:268]: pv_cache_add(): PV cache not >>> initialized, doing it now >>> 0(1378) ERROR: <core> [pvapi.c:828]: pv_parse_spec2(): error searching >>> pvar "avp" >>> 0(1378) ERROR: <core> [pvapi.c:1032]: pv_parse_spec2(): wrong char [s/115] >>> in [$avp(s:callfwd)] at [5 (5)] >>> 0(1378) : <core> [cfg.y:3368]: yyerror_at(): parse error in config file >>> /usr/local/etc/kamailio/kamailio.cfg, line 145, column 4-18: Can't get from >>> cache: $avp(s:callfwd) >>> ERROR: bad config file (1 errors) >>> >>> Here's what I think are the revelant portions of the config file: >>> >>> modparam("avpops", "db_url", "mysql://user:pass@localhost/kamailio") >>> modparam("avpops", "avp_table", "usr_preferences") >>> modparam("avpops", "uuid_column", "uuid") >>> modparam("avpops", "username_column", "username") >>> modparam("avpops", "domain_column", "domain") >>> modparam("avpops", "attribute_column", "attribute") >>> modparam("avpops", "value_column", "value") >>> modparam("avpops", "type_column", "type") >>> <snip> >>> if (avp_db_load("$from/username", >>> "$avp(s:callfwd)")) >>> { >>> if(!avp_db_delete("$from/username", >>> "$avp(s:callfwd)/usr_preferences")) >>> { >>> sl_send_reply("500", "Server DB >>> error"); } >>> } >>> >>> # avp_write("$ruri","$avp(s:callfwd)"); # Old OpenSER >>> 1.0 syntax... >>> $avp(s:callfwd) = $ruri; # New Kamailio syntax ?? >>> >>> avp_db_store("$from/username","$avp(s:callfwd)/usr_preferences"); >>> t_relay(); >>> return; >>> >>> Basically I just want to write the ruri into the usr_preferences >>> database with an attribute of callfwd but not sure what I'm missing. I >>> see the error "Can't get from cache" but not sure how that pertains to >>> what I'm trying to do. Anyone have any ideas? >>> >>> Thanks, >>> >>> Brian >>> >>> _______________________________________________ >>> SIP Express Router (SER) and Kamailio (OpenSER) - sr-users mailing list >>> sr-users@lists.sip-router.org >>> http://lists.sip-router.org/cgi-bin/mailman/listinfo/sr-users >> -- >> Daniel-Constantin Mierla >> http://twitter.com/#!/miconda - http://www.linkedin.com/in/miconda >> Kamailio Advanced Training, Berlin, Oct 24-26, 2016 - http://www.asipto.com -- Daniel-Constantin Mierla http://twitter.com/#!/miconda - http://www.linkedin.com/in/miconda Kamailio Advanced Training, Berlin, Oct 24-26, 2016 - http://www.asipto.com _______________________________________________ SIP Express Router (SER) and Kamailio (OpenSER) - sr-users mailing list sr-users@lists.sip-router.org http://lists.sip-router.org/cgi-bin/mailman/listinfo/sr-users