DrupalBin
Submit Code
About
Recent Posts
Code
Fix for Fix for Code
Fix for Code
Code
Node type whitelist
an axe coach accessories
coach purses married
Fix for de las ghd alturas
de las ghd alturas
Code
more
User login
Log in using OpenID:
What is OpenID?
Username:
*
Password:
*
Log in using OpenID
Cancel OpenID login
Create new account
Request new password
Tags
CCK
drupal
fapi
jquery
menu
module
php
simpletest
taxonomy
test
theme
views
more tags
Home
Fix for db_query reads fail
View
Fix
October 13, 2009 - 2:14pm — Anonymous
function
uc_imis_pricing_nodeapi
(
&
$node
,
$op
,
$a3
=
NULL
,
$a4
=
NULL
)
{
// pricing display ingetration point?
// ensure we have a product
if
(
$node
-
>
model
)
{
switch
(
$op
)
{
case
'load'
:
global
$user
;
$data
=
unserialize
(
$user
-
>
data
)
;
$imis_id
=
$data
[
'imis_id'
]
;
//if they're not an iMIS user, use the default pricing as defined on the product
//if ($imis_id != '') {
list
(
$meeting
,
$function
)
=
explode
(
'/'
,
$node
-
>
model
)
;
$ws
= _build_webservice
(
)
;
$event
=
node_load
(
$node
-
>
field_event
[
0
]
)
;
$member_type
=
$ws
-
>
get_member_type
(
$imis_id
)
;
$reg_class
=
$event
-
>
reg_class_mappings
[
$member_type
]
;
if
(
!
$reg_class
)
{
// use the default defined on the product
// pick a sensible default, at least for testing
$reg_class
=
'NM'
;
}
$node
-
>
sell_price
=
$ws
-
>
get_meeting_price
(
$meeting
,
$function
,
$reg_class
)
;
//load default class into node
$query
=
db_query
(
"SELECT * FROM {uc_imis_pricing WHERE vid = %d AND nid = %d"
,
$node
-
>
vid
,
$node
-
>
nid
)
;
dsm
(
$query
)
;
$node
-
>
default_class
=
$query
-
>
default_class
;
//}
break
;
case
'view'
:
// get rid of the "add to cart" button as we want them to make a registration node
if
(
isset
(
$node
-
>
content
[
'add_to_cart'
]
)
)
{
unset
(
$node
-
>
content
[
'add_to_cart'
]
)
;
}
break
;
case
'validate'
:
// possible discrimination between imis/non imis items?
$ws
= _build_webservice
(
)
;
// verify product exists
if
(
!
$ws
-
>
event_exists
(
$node
-
>
model
)
)
{
form_set_error
(
'model'
,
t
(
'That code does not exist in iMIS.'
)
)
;
}
break
;
case
'insert'
:
db_query
(
"INSERT INTO {uc_imis_pricing} (vid, nid, default_class) VALUES (%d, %d, '%s')"
,
$node
-
>
vid
,
$node
-
>
nid
,
$node
-
>
default_class
)
;
break
;
case
'update'
:
db_query
(
"UPDATE {uc_imis_pricing} SET default_class = '%s' WHERE vid = %d"
,
$node
-
>
default_class
,
$node
-
>
vid
)
;
break
;
}
}
}
module
ubercart
Submit Fix
Summary:
Tags:
Any tags you'd like to associate with your code, delimitered by commas (example: Views, CCK, Module, etc).
Show summary in full view
function uc_imis_pricing_nodeapi(&$node, $op, $a3 = NULL, $a4 = NULL) { // pricing display ingetration point? // ensure we have a product if ($node->model) { switch ($op) { case 'load': global $user; $data = unserialize($user->data); $imis_id = $data['imis_id']; //if they're not an iMIS user, use the default pricing as defined on the product //if ($imis_id != '') { list($meeting, $function) = explode('/', $node->model); $ws = _build_webservice(); $event = node_load($node->field_event[0]); $member_type = $ws->get_member_type($imis_id); $reg_class = $event->reg_class_mappings[$member_type]; if (! $reg_class) { // use the default defined on the product // pick a sensible default, at least for testing $reg_class = 'NM'; } $node->sell_price = $ws->get_meeting_price($meeting, $function, $reg_class); //load default class into node $query = db_query("SELECT * FROM {uc_imis_pricing WHERE vid = %d AND nid = %d", $node->vid, $node->nid); dsm($query); $node->default_class = $query->default_class; //} break; case 'view': // get rid of the "add to cart" button as we want them to make a registration node if(isset($node->content['add_to_cart'])) { unset($node->content['add_to_cart']); } break; case 'validate': // possible discrimination between imis/non imis items? $ws = _build_webservice(); // verify product exists if (! $ws->event_exists($node->model)) { form_set_error('model', t('That code does not exist in iMIS.')); } break; case 'insert': db_query("INSERT INTO {uc_imis_pricing} (vid, nid, default_class) VALUES (%d, %d, '%s')", $node->vid, $node->nid, $node->default_class); break; case 'update': db_query("UPDATE {uc_imis_pricing} SET default_class = '%s' WHERE vid = %d", $node->default_class, $node->vid); break; } } }
Syntax highlighting mode:
ActionScript
ColdFusion
Diff
Drupal 5
Drupal 6
HTML
INI
Javascript
MySQL
PHP
Python
robots.txt
SQL
Text
Select the syntax highlighting mode to use.
See Also:
Order
Title:
URL:
-1
0
1
Title:
URL:
-1
0
1
Any links you'd like to have associated with the post (Drupal.org issue, Wikipedia article, etc).
File attachments
Changes made to the attachments are not permanent until you save this post. The first "listed" file will be included in RSS feeds.
Attach new file:
The maximum upload size is
1 MB
. Only files with the following extensions may be uploaded:
jpg jpeg gif png txt doc xls pdf ppt pps odt ods odp phps
.