Skip to Content Skip to Menu

🌲 Last Day for Great Savings on Professional and Developer Memberships in 2024! Get 25% off now with code XMAS-2024!

[SOLVED] CB Auto Action to update a field in another table of the DB

  • ricco1
  • ricco1
  • OFFLINE
  • Posts: 310
  • Thanks: 8
  • Karma: -7
9 years 3 months ago - 9 years 3 months ago #269917 by ricco1
Hi Kyle,

Why is onCPayUserStateChange not listed in the drop down options or is it by any other name, I can't find it?

If I manually copy and paste onCPayUserStateChange then is comes and after I select it both User State Change and onCPayUserStateChange in the specified order are entered. Should I only use onCPayUserStateChange or should I leave both?

What is the difference between User State Change and onCPayUserStateChange?

Thank you
Last edit: 9 years 3 months ago by ricco1.

Please Log in or Create an account to join the conversation.

  • krileon
  • krileon
  • ONLINE
  • Posts: 48635
  • Thanks: 8307
  • Karma: 1446
9 years 3 months ago #269935 by krileon

Why is onCPayUserStateChange not listed in the drop down options or is it by any other name, I can't find it?

It's listed as "User State Change". The trigger labels are more user friendly.

If I manually copy and paste onCPayUserStateChange then is comes and after I select it both User State Change and onCPayUserStateChange in the specified order are entered. Should I only use onCPayUserStateChange or should I leave both?

You only need 1. It's adding the existing value plus your custom value. It's a bit weird behavior, but that's how select2 does it (probably fixed in next select2, but waiting for it to stabilize more).

What is the difference between User State Change and onCPayUserStateChange?

None, it's the same trigger. Once is just the pre-existing trigger option and the other is the one you added (it's a tags usage).


Kyle (Krileon)
Community Builder Team Member
Before posting on forums: Read FAQ thoroughly + Read our Documentation + Search the forums
CB links: Documentation - Localization - CB Quickstart - CB Paid Subscriptions - Add-Ons - Forge
--
If you are a Professional, Developer, or CB Paid Subscriptions subscriber and have a support issue please always post in your respective support forums for best results!
--
If I've missed your support post with a delay of 3 days or greater and are a Professional, Developer, or CBSubs subscriber please send me a private message with your thread and will reply when possible!
--
Please note I am available Monday - Friday from 8:00 AM CST to 4:00 PM CST. I am away on weekends (Saturday and Sunday) and if I've missed your post on or before a weekend after business hours please wait for the next following business day (Monday) and will get to your issue as soon as possible, thank you.
--
My role here is to provide guidance and assistance. I cannot provide custom code for each custom requirement. Please do not inquire me about custom development.

Please Log in or Create an account to join the conversation.

  • ricco1
  • ricco1
  • OFFLINE
  • Posts: 310
  • Thanks: 8
  • Karma: -7
9 years 3 months ago - 9 years 3 months ago #269954 by ricco1
It works with the "Before Draw Subscription" trigger, but not with "User State Change".

CBSubs SQL Actions doesn't do the job either.

Let me explain what am I trying to do:

I have a Free plan and a VIP plan.

First:

I need the value of a CB text field called "cb_vip" to be always 0 if the user is not a VIP member and 1 if the user is a VIP.

In my Free plan's CB Fields integration settings I have this:

Field "cb_vip"
Operator "Set: Field=Value"
Value "0"
Remove value on plan deactivation "No"(I've tried changing this to yes but it doesn't make any difference)

In my VIP plan's CB Fields integration settings I have this:

Field "cb_vip"
Operator "Set: Field=Value"
Value "1"
Remove value on plan deactivation "Yes"
Value on plan deactivation "0"

The value of the "cb_vip" field is not changed to 0 on VIP plan deactivation unfortunately, it changes to empty row, that's why I first need a CB Auto Action to change the value to 0.

Here is what is working currently, like I've said earlier:

Type: Field
Trigger: Before Draw Subscription
User: Automatic
Access: Everybody
Conditional: [cb_vip] Empty
Action:
Field [cb_vip]
Operator Set (Field=Value)
Value 0

If I change this to:

Type: Field
Trigger: User State Change
User: Automatic
Access: Everybody
Conditional: [cb_vip] Empty
Action:
Field [cb_vip]
Operator Set (Field=Value)
Value 0

It doesn't change the value to 0, but again to empty row (nothing is inside) and I can't use this field for list or other sorting. I need this field to have a value and not be empty.

Second:

Then, when I make sure that the "cb_vip" field is either 0 or 1 I need to update the corresponding field in my other table with the same value.

This is working currently:

Type: Query
Trigger: Before Draw Subscription
User: Automatic
Access: Everybody
Action: Query:
UPDATE `#__myothertable`
SET `vip_222` = (SELECT `cb_vip`
FROM `#__comprofiler`
WHERE `#__comprofiler`.`user_id` = `#__myothertable`.`222_id` AND `#__comprofiler`.`cb_vip` = 1);

UPDATE `#__myothertable`
SET `vip_222` = 0
WHERE `vip_222` != '1';

The "User State Change" trigger is not working again in the above action. Why?

Please tell me if there is any better way of achieving what I'm after?

Thank you,
Best regards,
ricco
Last edit: 9 years 3 months ago by ricco1.

Please Log in or Create an account to join the conversation.

  • krileon
  • krileon
  • ONLINE
  • Posts: 48635
  • Thanks: 8307
  • Karma: 1446
9 years 3 months ago - 9 years 3 months ago #269958 by krileon
You need to use User State Change for both of your actions. If you change a fields value for the user object with a Field action then a second action acts on that field then you need to enable reload user. Example as follows.

Action 1: Change field value
Action 2: Execute database query

They should be ordered as such in your auto actions. Action 2 should have Reload User enabled under its Parameters tab to ensure the new field value is picked up reliably.

The reason for this is CB Auto Actions can not know which variables are references. The only for it to do that is you have to specify which variables should be treated as references under Parameters. The easier solution in this case is to just have your second action reload the user object.

This should not be an issue if you're using CBSubs SQL Actions as there's no need to check a field value in it since their subscription would be setting them to VIP anyway.

Your query should also be updating 1 row. Not your entire table. That's going to lock an entire table. Adjust the where statement so the individual user updates as needed.


Kyle (Krileon)
Community Builder Team Member
Before posting on forums: Read FAQ thoroughly + Read our Documentation + Search the forums
CB links: Documentation - Localization - CB Quickstart - CB Paid Subscriptions - Add-Ons - Forge
--
If you are a Professional, Developer, or CB Paid Subscriptions subscriber and have a support issue please always post in your respective support forums for best results!
--
If I've missed your support post with a delay of 3 days or greater and are a Professional, Developer, or CBSubs subscriber please send me a private message with your thread and will reply when possible!
--
Please note I am available Monday - Friday from 8:00 AM CST to 4:00 PM CST. I am away on weekends (Saturday and Sunday) and if I've missed your post on or before a weekend after business hours please wait for the next following business day (Monday) and will get to your issue as soon as possible, thank you.
--
My role here is to provide guidance and assistance. I cannot provide custom code for each custom requirement. Please do not inquire me about custom development.
Last edit: 9 years 3 months ago by krileon.
The following user(s) said Thank You: ricco1

Please Log in or Create an account to join the conversation.

  • krileon
  • krileon
  • ONLINE
  • Posts: 48635
  • Thanks: 8307
  • Karma: 1446
9 years 3 months ago #269960 by krileon
Based off the information you've provided I'd just do the below in CBSubs and let CBSubs easily handle the entire scenario. Including reversal.

Plan > Integrations > CB Fields
Field: VIP
Operator: Set
Value: 1
Remove value on plan deactivation: Yes
Value on plan deactivation: 0

Plan > Integrations > SQL actions
Activation:
Code:
UPDATE `#__myothertable` SET `vip_222` = 1 WHERE `222_id` = '[user_id]';
Deactivation:
Code:
UPDATE `#__myothertable` SET `vip_222` = 0 WHERE `222_id` = '[user_id]';


Kyle (Krileon)
Community Builder Team Member
Before posting on forums: Read FAQ thoroughly + Read our Documentation + Search the forums
CB links: Documentation - Localization - CB Quickstart - CB Paid Subscriptions - Add-Ons - Forge
--
If you are a Professional, Developer, or CB Paid Subscriptions subscriber and have a support issue please always post in your respective support forums for best results!
--
If I've missed your support post with a delay of 3 days or greater and are a Professional, Developer, or CBSubs subscriber please send me a private message with your thread and will reply when possible!
--
Please note I am available Monday - Friday from 8:00 AM CST to 4:00 PM CST. I am away on weekends (Saturday and Sunday) and if I've missed your post on or before a weekend after business hours please wait for the next following business day (Monday) and will get to your issue as soon as possible, thank you.
--
My role here is to provide guidance and assistance. I cannot provide custom code for each custom requirement. Please do not inquire me about custom development.
The following user(s) said Thank You: ricco1

Please Log in or Create an account to join the conversation.

  • ricco1
  • ricco1
  • OFFLINE
  • Posts: 310
  • Thanks: 8
  • Karma: -7
9 years 3 months ago #269974 by ricco1
I will try it now and report.

Thank you Kyle.

Please Log in or Create an account to join the conversation.

Moderators: beatnantkrileon
Powered by Kunena Forum