Array comparion for multidimensinal array in php [duplicate] - php

This question already has answers here:
Closed 10 years ago.
Possible Duplicate:
recursive array_diff()?
Array 1 =>
pr($plan_data);
Array
(
[0] => Array
(
[AveragePrice] => 9.631161
[EFLUrl] => http://www.championenergyservices.com/register/EFL_API.asp?rateid=161456
[EarlyTerminationFee] => 150
[HurricaneRecovery] => 0.132
[MeterSurcharge] => 3.05
[OffCycle] => 5
[PUCAssessment] => 0.00167
[PlanDescription] => Savings Champ-6
[PlanId] => 57
[PlanIssueDate] => 12/10/2012
[PlanMonthlyFee] => 0
[PlanName] => PN1058
[PlanRate] => 9.3
[PlanRenewablePercent] => 7.2
[PlanTerm] => 6
[PriorityMoveIn] => 36
[ProviderDisplayName] => CenterPoint Energy
[ProviderId] => 21
[ProviderInternalName] => CNP_COAST
[RateId] => 161456
[RegularMoveIn] => 16
[TDSPPassThrough] => 0.03791
[TOCUrl] => http://www.championenergyservices.com/register/termsandconditions.asp?rateid=161456
[YRACUrl] => http://www.championenergyservices.com/register/\affiliatefiles\YRAC.PDF
[provider] => ces
[ProductType] => Fixed
[Rep] => Champion Energy Services
[Zone] => 77479
)
[1] => Array
(
[AveragePrice] => 10.1311693
[EFLUrl] => http://www.championenergyservices.com/register/EFL_API.asp?rateid=161458
[EarlyTerminationFee] => 150
[HurricaneRecovery] => 0.132
[MeterSurcharge] => 3.05
[OffCycle] => 5
[PUCAssessment] => 0.00167
[PlanDescription] => Savings Champ-12
[PlanId] => 59
[PlanIssueDate] => 12/10/2012
[PlanMonthlyFee] => 0
[PlanName] => PN1060
[PlanRate] => 9.8
[PlanRenewablePercent] => 7.2
[PlanTerm] => 12
[PriorityMoveIn] => 36
[ProviderDisplayName] => CenterPoint Energy
[ProviderId] => 21
[ProviderInternalName] => CNP_COAST
[RateId] => 161458
[RegularMoveIn] => 16
[TDSPPassThrough] => 0.03791
[TOCUrl] => http://www.championenergyservices.com/register/termsandconditions.asp?rateid=161458
[YRACUrl] => http://www.championenergyservices.com/register/\affiliatefiles\YRAC.PDF
[provider] => ces
[ProductType] => Fixed
[Rep] => Champion Energy Services
[Zone] => 77479
)
[2] => Array
(
[AveragePrice] => 10.4311743
[EFLUrl] => http://www.championenergyservices.com/register/EFL_API.asp?rateid=161459
[EarlyTerminationFee] => 150
[HurricaneRecovery] => 0.132
[MeterSurcharge] => 3.05
[OffCycle] => 5
[PUCAssessment] => 0.00167
[PlanDescription] => Green Power-12
[PlanId] => 60
[PlanIssueDate] => 12/10/2012
[PlanMonthlyFee] => 0
[PlanName] => PN1061
[PlanRate] => 10.1
[PlanRenewablePercent] => 100
[PlanTerm] => 12
[PriorityMoveIn] => 36
[ProviderDisplayName] => CenterPoint Energy
[ProviderId] => 21
[ProviderInternalName] => CNP_COAST
[RateId] => 161459
[RegularMoveIn] => 16
[TDSPPassThrough] => 0.03791
[TOCUrl] => http://www.championenergyservices.com/register/termsandconditions.asp?rateid=161459
[YRACUrl] => http://www.championenergyservices.com/register/\affiliatefiles\YRAC.PDF
[provider] => ces
[ProductType] => Fixed
[Rep] => Champion Energy Services
[Zone] => 77479
)
)
Array 2 =>
pr($temp_val);
Array
(
[0] => Array
(
[id] => 6
[PlanId] => 60
[PlanName] => Bounce 12 + A/C Protection
[PlanDescription] => Bounce 12 + A/C Protection - CNP
[PlanTerm] => 12
[PlanRate] =>
[RateId] =>
[PlanIssueDate] =>
[PlanMonthlyFee] =>
[EarlyTerminationFee] => 200.00000
[AveragePrice] => 12.00000
[HurricaneRecovery] =>
[PlanRenewablePercent] =>
[ProviderDisplayName] =>
[ProviderId] => 1
[provider] => bounce
[ProductZoneId] => 353
[Zone] => 77479
[ProviderInternalName] =>
[RegularMoveIn] =>
[PriorityMoveIn] =>
[OffCycle] =>
[TDSPPassThrough] =>
[PUCAssessment] =>
[EFLUrl] =>
[EFLLinkUrl] => http://www.bounceenergy.com/efls/bounce12.pdf
[TOCUrl] =>
[TOCLUrl] => http://www.bounceenergy.com/terms-of-service-fixed.pdf
[YRACUrl] =>
[YRACLUrl] => http://www.bounceenergy.com/yraac.pdf
[REP_Name] =>
[REP_PUCT] =>
[customer_service_email] =>
[toll_free_number] =>
[status] => active
[created] => 2012-12-14 12:40:05
[modified] => 2012-12-14
)
[1] => Array
(
[id] => 18
[PlanId] => 17
[PlanName] => Online Only - 12
[PlanDescription] => Online Only - 12
[PlanTerm] => 12
[PlanRate] =>
[RateId] => 386
[PlanIssueDate] =>
[PlanMonthlyFee] => 100.00000
[EarlyTerminationFee] => 175.00000
[AveragePrice] => 10.00000
[HurricaneRecovery] =>
[PlanRenewablePercent] =>
[ProviderDisplayName] =>
[ProviderId] => 2
[provider] => fulcrum
[ProductZoneId] =>
[Zone] => 77479
[ProviderInternalName] =>
[RegularMoveIn] =>
[PriorityMoveIn] =>
[OffCycle] =>
[TDSPPassThrough] =>
[PUCAssessment] =>
[EFLUrl] =>
[EFLLinkUrl] =>
[TOCUrl] =>
[TOCLUrl] =>
[YRACUrl] =>
[YRACLUrl] =>
[REP_Name] =>
[REP_PUCT] =>
[customer_service_email] =>
[toll_free_number] =>
[status] => active
[created] => 2012-12-14 12:40:15
[modified] => 2012-12-14
)
)
I want to compare this two array and if any key value is different i want to take it an different array..
$result_val= array_diff_assoc($plan_data, $temp_val);
Please help me out !!

Try something like this:
function array_diff_assoc($a, $b) {
$result = array();
foreach ($a as $k => $v) {
if ($b[$k] != $v) {
$result[$k] = [$v, $b[$k]];
}
}
return $result;
}

Related

PHP, CURL. What does curl_exec returns a string

I'm trying to set an API wit a CMS. The api code works fine. When I use var_dump the data I get is given below. I just want to extract records from it.
string(9219) "{"Details":{"PageNo":1,"TotalRecords":21,"TotalPages":6,"MethodName":"GetEntity"},"Error":{"ErrorCode":"200","ErrorDescription":"Request Successfully Accommodated"},"Records":[{"RecordId":"79245","Deleted":"N","CancellationWithNoRefund":"N","ShowOnWeb":"Y","BookNowOverrideOnWeb":"","WaitingListByEventOrSession":"","Active":"Y","Archive":"","DinnerType":"","StandardDay":"","EvacuationAssistanceRequired":"","IncludesMeals":"","FieldTrip":"","CpdAssignedToDelegate":"","Master":"","EventMaster":"","EnableApologies":"","MemberOnly":"N","AllowTableBooking":"","ExamDate":"","ExpiryDate":"","ArrivalDate":"","DepartDate":"","CutOffDate":"2021-12-20 00:00:00.000","BookingDeadline":"","StartDate":"2021-12-21 00:00:00.000","EndDate":"2021-12-21 00:00:00.000","DateDeleted":"","DateModified":"20/07/2021 14:53:14","DateCreated":"20/07/2021 13:30:11","NoOfDays":"1","AccreditionPoints":"","TotalTba":"0","MaximumSeats":"64","MinimumSeats":"1","TotalBookings":"1","TotalCancellations":"0","TotalRemoved":"","SeatsAvailable":"63","TotalOnWaitingList":"0","WaitingLimitPercentage":"12.5","WaitingLimitNumber":"8","EventCpdHours":"","MaximumAdditionalDelegates":"4","CommitteeName":"","SpeakerTutorOrganisationName":"","EventCode":"","ExpiryDaysName":"","ResponsibilityName":"","JoiningInstructions":"Further instructions will be emailed out ","RegionName":"Southe","Location":"","PromotionalCodeName":"","EventUrl":"","CampaignAppealName":"","CostCentreName":"","InternalId":"","SpeakerTutorName":"","LedgerAccountName":"","MainContactName":"","VatRateName":"Standard 20%","EventTypeName":"Golf Day","EventStatusName":"Open","VenueName":"Foxhills Golf Club & Resort","RegistrationTime":"","DeletedBy":"","EventName":"Golf Day 2021 SL","FomalTitle":"Golf Day 2021 SL","SourceFile":"","EventId":"Golf Day SL ","CreatedBy":"Sarah Lepak","ModifiedBy":"Sarah Lepak","LongDescription":"","Remarks":"","BookNowOverrideMessage":"","AccommodationNotes":"","NotesForWeb":"SL test golf day 2021","TCForWeb":"T's & C's here","ShortNotesForWeb":"","Committee":"","Responsibility":"","PromotionalCode":"","Region":"19053","SpeakerTutorOrganisation":"","ExpiryDays":"","CampaignAppeal":"","CostCentre":"","MainContact":"","Venue":"79240","EventStatus":"241","EventType":"227","LedgerAccount":"","VatRate":"19112","SpeakerTutor":"","StartTime":"10:30","EndTime":"16:00","WaitingListBy":"Event","CpdBy":"","SiteLayout":""},{"RecordId":"79244","Deleted":"N","CancellationWithNoRefund":"N","ShowOnWeb":"Y","BookNowOverrideOnWeb":"","WaitingListByEventOrSession":"","Active":"Y","Archive":"","DinnerType":"","StandardDay":"","EvacuationAssistanceRequired":"","IncludesMeals":"","FieldTrip":"","CpdAssignedToDelegate":"","Master":"","EventMaster":"","EnableApologies":"","MemberOnly":"N","AllowTableBooking":"","ExamDate":"","ExpiryDate":"","ArrivalDate":"","DepartDate":"","CutOffDate":"2021-09-20 00:00:00.000","BookingDeadline":"","StartDate":"2021-09-21 00:00:00.000","EndDate":"2021-09-21 00:00:00.000","DateDeleted":"","DateModified":"20/07/2021 13:30:03","DateCreated":"20/07/2021 13:30:01","NoOfDays":"1","AccreditionPoints":"","TotalTba":"0","MaximumSeats":"64","MinimumSeats":"1","TotalBookings":"0","TotalCancellations":"0","TotalRemoved":"","SeatsAvailable":"64","TotalOnWaitingList":"0","WaitingLimitPercentage":"78.13","WaitingLimitNumber":"50","EventCpdHours":"","MaximumAdditionalDelegates":"4","CommitteeName":"","SpeakerTutorOrganisationName":"","EventCode":"","ExpiryDaysName":"","ResponsibilityName":"","JoiningInstructions":"","RegionName":"Southe","Location":"","PromotionalCodeName":"","EventUrl":"","CampaignAppealName":"","CostCentreName":"","InternalId":"","SpeakerTutorName":"","LedgerAccountName":"","MainContactName":"","VatRateName":"Standard 20%","EventTypeName":"Golf Day","EventStatusName":"Open","VenueName":"Foxhills Golf Club & Resort","RegistrationTime":"","DeletedBy":"","EventName":"CB Golf Experience 2021","FomalTitle":"CB Golf Experience 2021","SourceFile":"","EventId":"CBGE21","CreatedBy":"Calvin Barnett","ModifiedBy":"Calvin Barnett","LongDescription":"","Remarks":"","BookNowOverrideMessage":"","AccommodationNotes":"","NotesForWeb":"Lorem ipsum Lorem ipsum","TCForWeb":"Cancellations more than 14 days ahead of the event will incur an administration fee of 10% per person deducted from their refund\r\n28 days ahead or less - a 50% refund will be given\r\n14 days ahead or less – no refunds will be given","ShortNotesForWeb":"","Committee":"","Responsibility":"","PromotionalCode":"","Region":"19053","SpeakerTutorOrganisation":"","ExpiryDays":"","CampaignAppeal":"","CostCentre":"","MainContact":"","Venue":"79240","EventStatus":"241","EventType":"227","LedgerAccount":"","VatRate":"19112","SpeakerTutor":"","StartTime":"14:00","EndTime":"17:00","WaitingListBy":"Event","CpdBy":"","SiteLayout":""},{"RecordId":"79243","Deleted":"N","CancellationWithNoRefund":"N","ShowOnWeb":"N","BookNowOverrideOnWeb":"","WaitingListByEventOrSession":"","Active":"Y","Archive":"","DinnerType":"","StandardDay":"","EvacuationAssistanceRequired":"","IncludesMeals":"","FieldTrip":"","CpdAssignedToDelegate":"","Master":"","EventMaster":"","EnableApologies":"","MemberOnly":"N","AllowTableBooking":"","ExamDate":"","ExpiryDate":"","ArrivalDate":"","DepartDate":"","CutOffDate":"","BookingDeadline":"","StartDate":"2022-08-30 00:00:00.000","EndDate":"2022-08-30 00:00:00.000","DateDeleted":"","DateModified":"20/07/2021 14:48:13","DateCreated":"20/07/2021 13:29:59","NoOfDays":"1","AccreditionPoints":"","TotalTba":"0","MaximumSeats":"65","MinimumSeats":"1","TotalBookings":"1","TotalCancellations":"0","TotalRemoved":"","SeatsAvailable":"64","TotalOnWaitingList":"0","WaitingLimitPercentage":"","WaitingLimitNumber":"","EventCpdHours":"","MaximumAdditionalDelegates":"4","CommitteeName":"","SpeakerTutorOrganisationName":"","EventCode":"","ExpiryDaysName":"","ResponsibilityName":"","JoiningInstructions":"","RegionName":"Eastmids","Location":"West lobby","PromotionalCodeName":"","EventUrl":"","CampaignAppealName":"","CostCentreName":"","InternalId":"","SpeakerTutorName":"","LedgerAccountName":"","MainContactName":"","VatRateName":"Standard 20%","EventTypeName":"Golf Day","EventStatusName":"Open","VenueName":"MilYork Test Venue","RegistrationTime":"","DeletedBy":"","EventName":"MY Golf Day 2022","FomalTitle":"MY Golf Day 2022","SourceFile":"","EventId":"MYGD22","CreatedBy":"Dawn Hall","ModifiedBy":"Dawn Hall","LongDescription":"","Remarks":"","BookNowOverrideMessage":"","AccommodationNotes":"","NotesForWeb":"Park in West wing carpark","TCForWeb":"This is a CRM test.","ShortNotesForWeb":"","Committee":"","Responsibility":"","PromotionalCode":"","Region":"19046","SpeakerTutorOrganisation":"","ExpiryDays":"","CampaignAppeal":"","CostCentre":"","MainContact":"","Venue":"77113","EventStatus":"241","EventType":"227","LedgerAccount":"","VatRate":"19112","SpeakerTutor":"","StartTime":"08:00","EndTime":"19:00","WaitingListBy":"Session","CpdBy":"","SiteLayout":""},{"RecordId":"79242","Deleted":"N","CancellationWithNoRefund":"N","ShowOnWeb":"Y","BookNowOverrideOnWeb":"","WaitingListByEventOrSession":"","Active":"Y","Archive":"","DinnerType":"","StandardDay":"","EvacuationAssistanceRequired":"","IncludesMeals":"","FieldTrip":"","CpdAssignedToDelegate":"","Master":"","EventMaster":"","EnableApologies":"","MemberOnly":"N","AllowTableBooking":"","ExamDate":"","ExpiryDate":"","ArrivalDate":"","DepartDate":"","CutOffDate":"2021-09-08 00:00:00.000","BookingDeadline":"","StartDate":"2021-09-08 00:00:00.000","EndDate":"2021-09-08 00:00:00.000","DateDeleted":"","DateModified":"20/07/2021 13:29:29","DateCreated":"20/07/2021 13:29:28","NoOfDays":"1","AccreditionPoints":"","TotalTba":"0","MaximumSeats":"64","MinimumSeats":"1","TotalBookings":"0","TotalCancellations":"0","TotalRemoved":"","SeatsAvailable":"64","TotalOnWaitingList":"0","WaitingLimitPercentage":"18.75","WaitingLimitNumber":"12","EventCpdHours":"","MaximumAdditionalDelegates":"4","CommitteeName":"","SpeakerTutorOrganisationName":"","EventCode":"","ExpiryDaysName":"","ResponsibilityName":"","JoiningInstructions":"First come first serve basis","RegionName":"Southe","Location":"","PromotionalCodeName":"","EventUrl":"","CampaignAppealName":"","CostCentreName":"","InternalId":"","SpeakerTutorName":"","LedgerAccountName":"","MainContactName":"","VatRateName":"Standard 20%","EventTypeName":"Golf Day","EventStatusName":"Open","VenueName":"Foxhills Golf Club & Resort","RegistrationTime":"","DeletedBy":"","EventName":"Annual Golf Day 2021 - CL Version","FomalTitle":"Annual Golf Day 2021 - CL Version","SourceFile":"","EventId":"CL- GD21","CreatedBy":"Charlie Lawrence","ModifiedBy":"Charlie Lawrence","LongDescription":"","Remarks":"","BookNowOverrideMessage":"","AccommodationNotes":"","NotesForWeb":"Annual Golf Day 2021","TCForWeb":"","ShortNotesForWeb":"","Committee":"","Responsibility":"","PromotionalCode":"","Region":"19053","SpeakerTutorOrganisation":"","ExpiryDays":"","CampaignAppeal":"","CostCentre":"","MainContact":"","Venue":"79240","EventStatus":"241","EventType":"227","LedgerAccount":"","VatRate":"19112","SpeakerTutor":"","StartTime":"08:00","EndTime":"16:00","WaitingListBy":"Session","CpdBy":"","SiteLayout":""}]}"
The API is returning a JSON string. Please try
$result = json_decode(curl_exec($curl));
$result is a php array.
Getting this reposes from the answer you provided.
How can I get the records only.
stdClass Object ( [Details] => stdClass Object ( [PageNo] => 1 [TotalRecords] => 21 [TotalPages] => 6 [MethodName] => GetEntity ) [Error] => stdClass Object ( [ErrorCode] => 200 [ErrorDescription] => Request Successfully Accommodated ) [Records] => Array ( [0] => stdClass Object ( [RecordId] => 79245 [Deleted] => N [CancellationWithNoRefund] => N [ShowOnWeb] => Y [BookNowOverrideOnWeb] => [WaitingListByEventOrSession] => [Active] => Y [Archive] => [DinnerType] => [StandardDay] => [EvacuationAssistanceRequired] => [IncludesMeals] => [FieldTrip] => [CpdAssignedToDelegate] => [Master] => [EventMaster] => [EnableApologies] => [MemberOnly] => N [AllowTableBooking] => [ExamDate] => [ExpiryDate] => [ArrivalDate] => [DepartDate] => [CutOffDate] => 2021-12-20 00:00:00.000 [BookingDeadline] => [StartDate] => 2021-12-21 00:00:00.000 [EndDate] => 2021-12-21 00:00:00.000 [DateDeleted] => [DateModified] => 20/07/2021 14:53:14 [DateCreated] => 20/07/2021 13:30:11 [NoOfDays] => 1 [AccreditionPoints] => [TotalTba] => 0 [MaximumSeats] => 64 [MinimumSeats] => 1 [TotalBookings] => 1 [TotalCancellations] => 0 [TotalRemoved] => [SeatsAvailable] => 63 [TotalOnWaitingList] => 0 [WaitingLimitPercentage] => 12.5 [WaitingLimitNumber] => 8 [EventCpdHours] => [MaximumAdditionalDelegates] => 4 [CommitteeName] => [SpeakerTutorOrganisationName] => [EventCode] => [ExpiryDaysName] => [ResponsibilityName] => [JoiningInstructions] => Further instructions will be emailed out [RegionName] => Southe [Location] => [PromotionalCodeName] => [EventUrl] => [CampaignAppealName] => [CostCentreName] => [InternalId] => [SpeakerTutorName] => [LedgerAccountName] => [MainContactName] => [VatRateName] => Standard 20% [EventTypeName] => Golf Day [EventStatusName] => Open [VenueName] => Foxhills Golf Club & Resort [RegistrationTime] => [DeletedBy] => [EventName] => Golf Day 2021 SL [FomalTitle] => Golf Day 2021 SL [SourceFile] => [EventId] => Golf Day SL [CreatedBy] => Sarah Lepak [ModifiedBy] => Sarah Lepak [LongDescription] => [Remarks] => [BookNowOverrideMessage] => [AccommodationNotes] => [NotesForWeb] => SL test golf day 2021 [TCForWeb] => T's & C's here [ShortNotesForWeb] => [Committee] => [Responsibility] => [PromotionalCode] => [Region] => 19053 [SpeakerTutorOrganisation] => [ExpiryDays] => [CampaignAppeal] => [CostCentre] => [MainContact] => [Venue] => 79240 [EventStatus] => 241 [EventType] => 227 [LedgerAccount] => [VatRate] => 19112 [SpeakerTutor] => [StartTime] => 10:30 [EndTime] => 16:00 [WaitingListBy] => Event [CpdBy] => [SiteLayout] => ) [1] => stdClass Object ( [RecordId] => 79244 [Deleted] => N [CancellationWithNoRefund] => N [ShowOnWeb] => Y [BookNowOverrideOnWeb] => [WaitingListByEventOrSession] => [Active] => Y [Archive] => [DinnerType] => [StandardDay] => [EvacuationAssistanceRequired] => [IncludesMeals] => [FieldTrip] => [CpdAssignedToDelegate] => [Master] => [EventMaster] => [EnableApologies] => [MemberOnly] => N [AllowTableBooking] => [ExamDate] => [ExpiryDate] => [ArrivalDate] => [DepartDate] => [CutOffDate] => 2021-09-20 00:00:00.000 [BookingDeadline] => [StartDate] => 2021-09-21 00:00:00.000 [EndDate] => 2021-09-21 00:00:00.000 [DateDeleted] => [DateModified] => 20/07/2021 13:30:03 [DateCreated] => 20/07/2021 13:30:01 [NoOfDays] => 1 [AccreditionPoints] => [TotalTba] => 0 [MaximumSeats] => 64 [MinimumSeats] => 1 [TotalBookings] => 0 [TotalCancellations] => 0 [TotalRemoved] => [SeatsAvailable] => 64 [TotalOnWaitingList] => 0 [WaitingLimitPercentage] => 78.13 [WaitingLimitNumber] => 50 [EventCpdHours] => [MaximumAdditionalDelegates] => 4 [CommitteeName] => [SpeakerTutorOrganisationName] => [EventCode] => [ExpiryDaysName] => [ResponsibilityName] => [JoiningInstructions] => [RegionName] => Southe [Location] => [PromotionalCodeName] => [EventUrl] => [CampaignAppealName] => [CostCentreName] => [InternalId] => [SpeakerTutorName] => [LedgerAccountName] => [MainContactName] => [VatRateName] => Standard 20% [EventTypeName] => Golf Day [EventStatusName] => Open [VenueName] => Foxhills Golf Club & Resort [RegistrationTime] => [DeletedBy] => [EventName] => CB Golf Experience 2021 [FomalTitle] => CB Golf Experience 2021 [SourceFile] => [EventId] => CBGE21 [CreatedBy] => Calvin Barnett [ModifiedBy] => Calvin Barnett [LongDescription] => [Remarks] => [BookNowOverrideMessage] => [AccommodationNotes] => [NotesForWeb] => Lorem ipsum Lorem ipsum [TCForWeb] => Cancellations more than 14 days ahead of the event will incur an administration fee of 10% per person deducted from their refund 28 days ahead or less - a 50% refund will be given 14 days ahead or less – no refunds will be given [ShortNotesForWeb] => [Committee] => [Responsibility] => [PromotionalCode] => [Region] => 19053 [SpeakerTutorOrganisation] => [ExpiryDays] => [CampaignAppeal] => [CostCentre] => [MainContact] => [Venue] => 79240 [EventStatus] => 241 [EventType] => 227 [LedgerAccount] => [VatRate] => 19112 [SpeakerTutor] => [StartTime] => 14:00 [EndTime] => 17:00 [WaitingListBy] => Event [CpdBy] => [SiteLayout] => ) [2] => stdClass Object ( [RecordId] => 79243 [Deleted] => N [CancellationWithNoRefund] => N [ShowOnWeb] => N [BookNowOverrideOnWeb] => [WaitingListByEventOrSession] => [Active] => Y [Archive] => [DinnerType] => [StandardDay] => [EvacuationAssistanceRequired] => [IncludesMeals] => [FieldTrip] => [CpdAssignedToDelegate] => [Master] => [EventMaster] => [EnableApologies] => [MemberOnly] => N [AllowTableBooking] => [ExamDate] => [ExpiryDate] => [ArrivalDate] => [DepartDate] => [CutOffDate] => [BookingDeadline] => [StartDate] => 2022-08-30 00:00:00.000 [EndDate] => 2022-08-30 00:00:00.000 [DateDeleted] => [DateModified] => 20/07/2021 14:48:13 [DateCreated] => 20/07/2021 13:29:59 [NoOfDays] => 1 [AccreditionPoints] => [TotalTba] => 0 [MaximumSeats] => 65 [MinimumSeats] => 1 [TotalBookings] => 1 [TotalCancellations] => 0 [TotalRemoved] => [SeatsAvailable] => 64 [TotalOnWaitingList] => 0 [WaitingLimitPercentage] => [WaitingLimitNumber] => [EventCpdHours] => [MaximumAdditionalDelegates] => 4 [CommitteeName] => [SpeakerTutorOrganisationName] => [EventCode] => [ExpiryDaysName] => [ResponsibilityName] => [JoiningInstructions] => [RegionName] => Eastmids [Location] => West lobby [PromotionalCodeName] => [EventUrl] => [CampaignAppealName] => [CostCentreName] => [InternalId] => [SpeakerTutorName] => [LedgerAccountName] => [MainContactName] => [VatRateName] => Standard 20% [EventTypeName] => Golf Day [EventStatusName] => Open [VenueName] => MilYork Test Venue [RegistrationTime] => [DeletedBy] => [EventName] => MY Golf Day 2022 [FomalTitle] => MY Golf Day 2022 [SourceFile] => [EventId] => MYGD22 [CreatedBy] => Dawn Hall [ModifiedBy] => Dawn Hall [LongDescription] => [Remarks] => [BookNowOverrideMessage] => [AccommodationNotes] => [NotesForWeb] => Park in West wing carpark [TCForWeb] => This is a CRM test. [ShortNotesForWeb] => [Committee] => [Responsibility] => [PromotionalCode] => [Region] => 19046 [SpeakerTutorOrganisation] => [ExpiryDays] => [CampaignAppeal] => [CostCentre] => [MainContact] => [Venue] => 77113 [EventStatus] => 241 [EventType] => 227 [LedgerAccount] => [VatRate] => 19112 [SpeakerTutor] => [StartTime] => 08:00 [EndTime] => 19:00 [WaitingListBy] => Session [CpdBy] => [SiteLayout] => ) [3] => stdClass Object ( [RecordId] => 79242 [Deleted] => N [CancellationWithNoRefund] => N [ShowOnWeb] => Y [BookNowOverrideOnWeb] => [WaitingListByEventOrSession] => [Active] => Y [Archive] => [DinnerType] => [StandardDay] => [EvacuationAssistanceRequired] => [IncludesMeals] => [FieldTrip] => [CpdAssignedToDelegate] => [Master] => [EventMaster] => [EnableApologies] => [MemberOnly] => N [AllowTableBooking] => [ExamDate] => [ExpiryDate] => [ArrivalDate] => [DepartDate] => [CutOffDate] => 2021-09-08 00:00:00.000 [BookingDeadline] => [StartDate] => 2021-09-08 00:00:00.000 [EndDate] => 2021-09-08 00:00:00.000 [DateDeleted] => [DateModified] => 20/07/2021 13:29:29 [DateCreated] => 20/07/2021 13:29:28 [NoOfDays] => 1 [AccreditionPoints] => [TotalTba] => 0 [MaximumSeats] => 64 [MinimumSeats] => 1 [TotalBookings] => 0 [TotalCancellations] => 0 [TotalRemoved] => [SeatsAvailable] => 64 [TotalOnWaitingList] => 0 [WaitingLimitPercentage] => 18.75 [WaitingLimitNumber] => 12 [EventCpdHours] => [MaximumAdditionalDelegates] => 4 [CommitteeName] => [SpeakerTutorOrganisationName] => [EventCode] => [ExpiryDaysName] => [ResponsibilityName] => [JoiningInstructions] => First come first serve basis [RegionName] => Southe [Location] => [PromotionalCodeName] => [EventUrl] => [CampaignAppealName] => [CostCentreName] => [InternalId] => [SpeakerTutorName] => [LedgerAccountName] => [MainContactName] => [VatRateName] => Standard 20% [EventTypeName] => Golf Day [EventStatusName] => Open [VenueName] => Foxhills Golf Club & Resort [RegistrationTime] => [DeletedBy] => [EventName] => Annual Golf Day 2021 - CL Version [FomalTitle] => Annual Golf Day 2021 - CL Version [SourceFile] => [EventId] => CL- GD21 [CreatedBy] => Charlie Lawrence [ModifiedBy] => Charlie Lawrence [LongDescription] => [Remarks] => [BookNowOverrideMessage] => [AccommodationNotes] => [NotesForWeb] => Annual Golf Day 2021 [TCForWeb] => [ShortNotesForWeb] => [Committee] => [Responsibility] => [PromotionalCode] => [Region] => 19053 [SpeakerTutorOrganisation] => [ExpiryDays] => [CampaignAppeal] => [CostCentre] => [MainContact] => [Venue] => 79240 [EventStatus] => 241 [EventType] => 227 [LedgerAccount] => [VatRate] => 19112 [SpeakerTutor] => [StartTime] => 08:00 [EndTime] => 16:00 [WaitingListBy] => Session [CpdBy] => [SiteLayout] => ) ) )

count and addition the array values in array php

I have one array data output coming below format. i want to add total adults count with in the array.My out is below please find.
Array
(
[0] => stdClass Object
(
[id] => 4534
[api] => expedia
[AL_RefNo] => H190100000062
[modify_refno] => H190100000062_1
[Hotel_RefNo] => 325758353
[Booking_RefNo] => 1234
[affiliateConfirmationId] => OMEIR-1P3IWK2G8UXTIT5E2ELI2T2H1QI4H7
[room_no] => 1
[room_type] => Deluxe Double or Twin Room
[arrivalDate] => 02/20/2019
[departureDate] => 02/21/2019
[nights] => 1
[adults] => 1
[childs] => 2
[childs_ages] => 6,8
[bedTypeId] =>
[rateKey] => 26963a10-0e8d-41e0-ad55-478b8b2280fb
[booking_status] => Confirmed
[first_name] => hjgkjug
[middle_name] =>
[last_name] => jh
[averageBaseRate] => 48.46
[averageRate] => 48.46
[commissionableUsdTotal] => 48.46
[currency_val] => 1
[Currency] => AED
[Xml_Currency] => USD
[eanCompensationOffline] => 0
[eanCompensationOnline] => 0
[maxNightlyRate] => 48.46
[nightlyRateTotal] => 48.46
[grossProfitOffline] => 0
[grossProfitOnline] => 0
[TotalBasePrice] => 61
[TotalEqualBasePrice] =>
[TotalEqualTax] =>
[TotalTax] => 13
[markup_type] =>
[markup_percentage] =>
[markup_amount] =>
[markup_value_amount] => 0
[markup_value_percentage] => 10.0000
[extra_markup] => 0
[extra_markup_percentage] => 0
[markup_effective_to] => 2019-02-27
[markup_per_night] => No
[customer_markup] => 6.107
[ota_discount_amount] => 0.00
[ota_discount_type] =>
[ota_discount_cal_amount] => 0.00
[total] => 70.53585
[dailyPrice] =>
[surchargeTotal] => 12.61
[NightlyRatesPerRoomsize] => 1
[NightlyRatePromo] => false
[baseRate] => 48.46
[rate] => 48.46
[surchargesSize] => 1
[surchargeType] => TaxAndServiceFee
[surchargeAmount] => 12.61
[ratePlanType] =>
[processedWithConfirmation] => true
[booking_date] => 2019-01-17 15:01:01
[remarks] => Refundable
[room_type_code] =>
[rateIdentifier] =>
[status] =>
[roomTotalPrice] =>
[serviceDate] =>
[dailypriceType] =>
[mealBasisCodeDay] =>
[mealIdDay] =>
[mealTypeDay] =>
[descriptionDay] =>
[roomDescription] =>
[roomCategory] =>
[transactionID] =>
[payment_charge] =>
[room_code] =>
[description] =>
[commission] =>
[gross_price] =>
[nett_price] =>
[Cancellation_Charge] =>
[Cancel_Till_Date] =>
[Cancelled_By] =>
[rateClass] =>
[rateComments] =>
[paymentType] =>
[packaging] =>
[cancel_amount] =>
[cancel_from_date] =>
[actual_hotel_confirmation_number] =>
[meal_type] => Free Wireless Internet|Free Breakfast
[supplier_price] =>
[sell_price] =>
[client_price] =>
[total_sell_price] =>
[ota_booking_status] =>
[Cancellation_Status] =>
[Cancellation_Charge_Amount] =>
[Cancelled_Markup] =>
[Cancelled_Extra_Markup] =>
[Refundable_Amont] =>
[room_daily_rates] => [{"offset":1,"providerCost":48.46,"baseRate":48.46,"promo":"false","checkIn":"20-02-2019","totalTax":12.61,"inputVat":0,"markup":6.107,"eMarkup":0,"discount":"","outputVat":3.6642,"totalAmount":70.8412,"status":"A"}]
[vat_effective_to] => 2050-02-01
[vat_price] => 3.36
[vat_percentage] => 5
[input_vat_percentage] => 0
[input_vat_price] => 0
[cost_components] => ["Base Price","Markup"]
[register_supplier] => Yes
[inclusive_vat] => No
[gcc_supplier] =>
[price_rate_with_triple_plus] =>
[hotel_service_percentage] =>
[tourism_fee_percentage] =>
[municipality_fee_percentage] =>
[hotel_service_price] =>
[tourism_fee_price] =>
[municipality_fee_price] =>
[direct_hotel_booking] => No
[supplier_cancellation_charge] =>
[vat_cancellation_charge] =>
[modify_booking_status] =>
[parent_modify_refno] =>
[refundable_status] => Refundable
[modify_status] => Yes
[updated_on] => 2019-01-17 19:56:55
)
[1] => stdClass Object
(
[id] => 4535
[api] => expedia
[AL_RefNo] => H190100000062
[modify_refno] => H190100000062_1
[Hotel_RefNo] => 325758353
[Booking_RefNo] => 1235
[affiliateConfirmationId] => OMEIR-1P3IWK2G8UXTIT5E2ELI2T2H1QI4H7
[room_no] => 2
[room_type] => Deluxe Double or Twin Room
[arrivalDate] => 02/20/2019
[departureDate] => 02/21/2019
[nights] => 1
[adults] => 2
[childs] => 1
[childs_ages] => 10
[bedTypeId] =>
[rateKey] => 5baad87e-8d89-43fc-8553-357e885e7f0c
[booking_status] => Confirmed
[first_name] => hjgkjug
[middle_name] =>
[last_name] => jh
[averageBaseRate] => 48.46
[averageRate] => 48.46
[commissionableUsdTotal] => 48.46
[currency_val] => 1
[Currency] => AED
[Xml_Currency] => USD
[eanCompensationOffline] => 0
[eanCompensationOnline] => 0
[maxNightlyRate] => 48.46
[nightlyRateTotal] => 48.46
[grossProfitOffline] => 0
[grossProfitOnline] => 0
[TotalBasePrice] => 61
[TotalEqualBasePrice] =>
[TotalEqualTax] =>
[TotalTax] => 13
[markup_type] =>
[markup_percentage] =>
[markup_amount] =>
[markup_value_amount] => 0
[markup_value_percentage] => 10.0000
[extra_markup] => 0
[extra_markup_percentage] => 0
[markup_effective_to] => 2019-02-27
[markup_per_night] => No
[customer_markup] => 6.107
[ota_discount_amount] => 0.00
[ota_discount_type] =>
[ota_discount_cal_amount] => 0.00
[total] => 70.53585
[dailyPrice] =>
[surchargeTotal] => 12.61
[NightlyRatesPerRoomsize] => 1
[NightlyRatePromo] => false
[baseRate] => 48.46
[rate] => 48.46
[surchargesSize] => 1
[surchargeType] => TaxAndServiceFee
[surchargeAmount] => 12.61
[ratePlanType] =>
[processedWithConfirmation] => true
[booking_date] => 2019-01-17 15:01:01
[remarks] => Refundable
[room_type_code] =>
[rateIdentifier] =>
[status] =>
[roomTotalPrice] =>
[serviceDate] =>
[dailypriceType] =>
[mealBasisCodeDay] =>
[mealIdDay] =>
[mealTypeDay] =>
[descriptionDay] =>
[roomDescription] =>
[roomCategory] =>
[transactionID] =>
[payment_charge] =>
[room_code] =>
[description] =>
[commission] =>
[gross_price] =>
[nett_price] =>
[Cancellation_Charge] =>
[Cancel_Till_Date] =>
[Cancelled_By] =>
[rateClass] =>
[rateComments] =>
[paymentType] =>
[packaging] =>
[cancel_amount] =>
[cancel_from_date] =>
[actual_hotel_confirmation_number] =>
[meal_type] => Free Wireless Internet|Free Breakfast
[supplier_price] =>
[sell_price] =>
[client_price] =>
[total_sell_price] =>
[ota_booking_status] =>
[Cancellation_Status] =>
[Cancellation_Charge_Amount] =>
[Cancelled_Markup] =>
[Cancelled_Extra_Markup] =>
[Refundable_Amont] =>
[room_daily_rates] => [{"offset":1,"providerCost":48.46,"baseRate":48.46,"promo":"false","checkIn":"20-02-2019","totalTax":12.61,"inputVat":0,"markup":6.107,"eMarkup":0,"discount":"","outputVat":3.6642,"totalAmount":70.8412,"status":"A"}]
[vat_effective_to] => 2050-02-01
[vat_price] => 3.36
[vat_percentage] => 5
[input_vat_percentage] => 0
[input_vat_price] => 0
[cost_components] => ["Base Price","Markup"]
[register_supplier] => Yes
[inclusive_vat] => No
[gcc_supplier] =>
[price_rate_with_triple_plus] =>
[hotel_service_percentage] =>
[tourism_fee_percentage] =>
[municipality_fee_percentage] =>
[hotel_service_price] =>
[tourism_fee_price] =>
[municipality_fee_price] =>
[direct_hotel_booking] => No
[supplier_cancellation_charge] =>
[vat_cancellation_charge] =>
[modify_booking_status] =>
[parent_modify_refno] =>
[refundable_status] => Refundable
[modify_status] => Yes
[updated_on] => 2019-01-17 19:56:55
)
)
Here in array object adults is total 1+2 =3 and childs is total 2+1=3.
i tried below code not working
foreach($room_details as $adultcount){
echo $adultcount->adults;
echo $adultcount->childs;
}
can any one please check and tell me where is the mistake in this code. i tried so many times not working below code.
Try something like this:
$adult_count = 0;
$child_count = 0;
foreach($room_details as $count){
$adult_count += $count->adults;
$child_count += $count->childs;
}
echo $adult_count;
echo $child_count;

how to print multiple array in joomla

This is the cart array in the Virtuemart 2.0.22a ..
this is stored in "$cart"
how to print [virtuemart_product_id] => 21 at 4.
$cart=
VirtueMartCart Object
(
[products] => Array
(
[21] => stdClass Object
(
[virtuemart_manufacturer_id] => Array
(
)
[slug] => stylish-shirt
[published] => 1
[virtuemart_product_price] =>
[virtuemart_product_id] => 21
[virtuemart_shoppergroup_id] =>
[product_price] => 450.00000
[override] => 0
[product_override_price] => 0.00000
[product_tax_id] => -1
[product_discount_id] => -1
[product_currency] => 68
[virtuemart_vendor_id] => 1
[product_parent_id] => 0
[product_sku] =>
[product_name] => Stylish Shirt
[product_s_desc] =>
[product_weight] =>
[product_weight_uom] => KG
[product_length] =>
[product_width] =>
[product_height] =>
[product_lwh_uom] => M
[product_in_stock] => 0
[product_ordered] => 0
[product_sales] => 0
[product_unit] => KG
[product_packaging] =>
[min_order_level] =>
[max_order_level] =>
[virtuemart_media_id] => Array
(
[0] => 21
)
[step_order_level] =>
[image] => VmImage Object
(
[media_attributes] => 0
[setRole] =>
[file_name] => 3
[file_extension] => jpg
[virtuemart_media_id] => 21
[_foldersToTest:VmMediaHandler:private] => Array
(
[0] => E:\wamp\www\ecomm\images\stories\virtuemart\product\
[1] => E:\wamp\www\ecomm\images\stories\virtuemart\product\resized\
)
[_actions:VmMediaHandler:private] => Array
(
)
[_mLocation:VmMediaHandler:private] => Array
(
)
[_hidden:VmMediaHandler:private] => Array
(
)
[theme_url] => http://localhost/ecomm/components/com_virtuemart/
[virtuemart_vendor_id] => 1
[file_title] => 3.jpg
[file_description] =>
[file_meta] =>
[file_mimetype] => image/jpeg
[file_type] => product
[file_url] => images/stories/virtuemart/product/3.jpg
[file_url_thumb] => images/stories/virtuemart/product/resized/3_90x90.jpg
[published] => 1
[file_is_downloadable] => 0
[file_is_forSale] => 0
[file_is_product_image] => 0
[shared] => 0
[file_params] =>
[file_lang] =>
[_translatable] =>
[_tablePreFix] =>
[created_on] => 2013-08-12 12:32:19
[created_by] => 572
[modified_on] => 2013-08-12 12:38:50
[modified_by] => 572
[file_url_folder] => images/stories/virtuemart/product/
[file_path_folder] => images\stories\virtuemart\product\
[file_url_folder_thumb] => images/stories/virtuemart/product/resized/
[media_role] => file_is_displayable
[file_name_thumb] => 3_90x90
)
[categories] => Array
(
[0] => 6
)
[virtuemart_category_id] => 6
[category_name] => Shirts
[link] => /ecomm/index.php/component/virtuemart/shirts/stylish-shirt-detail?Itemid=0
[packaging] =>
[quantity] => 1
)
)
[_inCheckOut] =>
[_dataValidated] =>
[_blockConfirm] =>
[_confirmDone] =>
[_redirect] =>
[_redirect_disabled] =>
[_lastError] =>
[vendorId] => 1
[lastVisitedCategoryId] => 0
[virtuemart_shipmentmethod_id] => 0
[virtuemart_paymentmethod_id] => 1
[automaticSelectedShipment] => 1
[automaticSelectedPayment] => 1
[BT] => 0
[ST] => 0
[tosAccepted] =>
[customer_comment] =>
[couponCode] =>
[order_language] =>
[cartData] => Array
(
[VatTax] => Array
(
)
[duty] => 1
[payment] => 0
[paymentName] =>
Finally i got the output.. after lot of struggles
foreach($cart->products as $cur)
{
echo $cur->virtuemart_product_id;
}

Magento accessing nested data

I have an object I'm trying to access data from but don't seem to be able to get to it.
Using Mage::log($request->debug());
I get the following output
Array
(
[all_items] => Array
(
[0 (Mage_Sales_Model_Quote_Item)] => Array
(
[item_id] => 593
[quote_id] => 536
[created_at] => 2012-07-12 11:40:17
[updated_at] => 2012-07-12 12:10:31
[product_id] => 37191
[store_id] => 8
[is_virtual] => 0
[sku] => 30018025
[name] => Fish Snowboard 2012
[free_shipping] =>
[is_qty_decimal] => 0
[no_discount] => 0
[weight] => 5000.0000
[qty] => 1
[price] => 429.12
[base_price] => 429.12
[discount_percent] => 0.0000
[discount_amount] => 0.0000
[base_discount_amount] => 0.0000
[tax_percent] => 20
[tax_amount] => 85.8200
[base_tax_amount] => 85.8200
[row_total] => 429.12
[base_row_total] => 429.12
[row_total_with_discount] => 0.0000
[row_weight] => 5000
[product_type] => simple
[price_incl_tax] => 514.94
[base_price_incl_tax] => 514.9400
[row_total_incl_tax] => 514.94
[base_row_total_incl_tax] => 514.94
[weee_tax_disposition] => 0
[weee_tax_row_disposition] => 0
[base_weee_tax_disposition] => 0
[base_weee_tax_row_disposition] => 0
[weee_tax_applied] => a:0:{}
[weee_tax_applied_amount] => 0
[weee_tax_applied_row_amount] => 0
[base_weee_tax_applied_amount] => 0
[qty_options] => Array
(
)
[product (OrganicInternet_SimpleConfigurableProducts_Catalog_Model_Product)] => Array
(
[entity_id] => 37191
[entity_type_id] => 4
[attribute_set_id] => 10
[type_id] => simple
[sku] => 30018025
[has_options] => 0
[required_options] => 0
[created_at] => 2011-06-19 17:34:46
[updated_at] => 2012-01-19 14:28:08
[name] => Fish Snowboard 2012
[small_image] => /f/i/fish-snowboard-2012-164.jpg
[thumbnail] => /f/i/fish-snowboard-2012-164.jpg
[url_key] => burton-fish-snowboard-2012-164cm
[url_path] => burton-fish-snowboard-2012-164cm
[msrp_enabled] => Use config
[msrp_display_actual_price_type] => Use config
[gift_message_available] =>
[status] => 1
[visibility] => 4
[enable_googlecheckout] => 1
[tax_class_id] => 2
[price] => 524.9400
[weight] => 5000.0000
[is_salable] => 1
[stock_item (Mage_CatalogInventory_Model_Stock_Item)] => Array
(
[item_id] => 35510
[product_id] => 37191
[stock_id] => 1
[qty] => 2.0000
[min_qty] => 0.0000
[use_config_min_qty] => 1
[is_qty_decimal] => 0
[backorders] => 0
[use_config_backorders] => 1
[min_sale_qty] => 1.0000
[use_config_min_sale_qty] => 1
[max_sale_qty] => 0.0000
[use_config_max_sale_qty] => 1
[is_in_stock] => 1
[notify_stock_qty] => 0.0000
[use_config_notify_stock_qty] => 1
[manage_stock] => 1
[use_config_manage_stock] => 1
[stock_status_changed_auto] => 0
[stock_status_changed_automatically] => 0
[use_config_qty_increments] => 1
[qty_increments] => 0.0000
[use_config_enable_qty_inc] => 1
[use_config_enable_qty_increments] => 1
[enable_qty_increments] => 0
[type_id] => simple
[stock_status] => 1
[product_name] => Fish Snowboard 2012
[store_id] => 8
[product_type_id] => simple
[product_status_changed] => 1
[ordered_items] => 1
)
[request_path] => burton-fish-snowboard-2012-164cm
[tier_price] => Array
(
)
[is_in_stock] => 1
[store_id] => 8
[customer_group_id] => 0
)
[tax_class_id] => 2
[has_error] =>
[is_nominal] =>
[base_original_price] => 514.9400
[taxable_amount] => 514.94
[base_taxable_amount] => 514.94
[is_price_incl_tax] => 1
[discount_calculation_price] => 429.12
[base_discount_calculation_price] => 429.12
[base_weee_tax_applied_row_amount] => 0
)
)
[dest_country_id] => GB
[dest_region_code] =>
[dest_street] => ndjn
[dest_city] => ihho
[dest_postcode] => iohih
[package_value] => 514.94
[package_value_with_discount] => 429.12
[package_weight] => 5000
[package_qty] => 1
[package_physical_value] => 429.12
[free_method_weight] => 5000
[store_id] => 8
[website_id] => 4
[free_shipping] => 0
[base_currency (Mage_Directory_Model_Currency)] => Array
(
[currency_code] => GBP
)
[package_currency (Mage_Directory_Model_Currency)] => Array
(
[currency_code] => GBP
)
[country_id] => GB
[region_id] => 0
[city] =>
[postcode] =>
[p_rcondition_name] => package_standard
[ignore_free_items] =>
)
I'd like to access $request[all_items][0][price] and $request[all_items][0][product][price]
I've tried a view different ways but no matter what I do I just don't seem to be able to get the bits I want out.
I'm sure its simple once you know how :P
You can try this :
$items = $request->getAllItems();
$itemPrice = $items[0]->getPrice();
$productPrice = $items[0]->getProduct()->getPrice();
You'll find some informations about Varien_Object here : http://alanstorm.com/magento_varien_object_debugging

Cakephp Containable not attaching to Model

I've used containable tons of times but I can not figure for the life of me why it is not working correctly now.
I have 3 models Project, User, and Country.
Project belongsTo User
User belongsTo Country
here is the models
<?php
class User extends AppModel {
var $name = 'User';
var $displayField = 'username';
var $belongsTo = array(
'AccountType' => array(
'className' => 'AccountType',
'foreignKey' => 'account_type_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'PaymentType' => array(
'className' => 'PaymentType',
'foreignKey' => 'payment_type_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'Country' => array(
'className' => 'Country',
'foreignKey' => 'country_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'InstantMessenger' => array(
'className' => 'InstantMessenger',
'foreignKey' => 'instant_messenger_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'TimeZone' => array(
'className' => 'TimeZone',
'foreignKey' => 'time_zone_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'Language' => array(
'className' => 'Language',
'foreignKey' => 'language_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
);
}
<?php
class Project extends AppModel {
var $name = 'Project';
var $displayField = 'project_title';
var $belongsTo = array(
'User' => array(
'className' => 'User',
'conditions' => '',
'fields' => '',
'order' => ''
),
'ProjectType' => array(
'className' => 'ProjectType',
'foreignKey' => 'project_type_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'BiddingType' => array(
'className' => 'BiddingType',
'foreignKey' => 'bidding_type_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'ProjectStatus' => array(
'className' => 'ProjectStatus',
'foreignKey' => 'project_status',
'conditions' => '',
'fields' => '',
'order' => ''
),
'EmploymentType',
'PaymentType',
);
}
<?php
class Country extends AppModel {
var $name = 'Country';
var $displayField = 'name';
//The Associations below have been created with all possible keys, those that are not needed can be removed
var $hasMany = array(
'User' => array(
'className' => 'User',
'foreignKey' => 'country_id',
'dependent' => false,
'conditions' => '',
'fields' => '',
'order' => '',
'limit' => '',
'offset' => '',
'exclusive' => '',
'finderQuery' => '',
'counterQuery' => ''
)
);
}
Now here is my code to try to attach a containable to project and add User
function smartbid($projid = null)
{
$this->loadModel('Content');
$content = $this->Content->findById(53);
$this->set('content',$content);
$this->Project->Behaviors->attach('Containable');
$options = array(
array(
'conditions'=>
array(
'Project.id'=>$projid
),
'contain'=>array(
'User'
)
)
);
$project = $this->Project->find('first',$options);
$this->set(compact('project'));
}
Now cakephp completely ignores my attached containable and returns this
Array
(
[Project] => Array
(
[id] => 1
[user_id] => 19
[status] => 1
[approval_status] => 0
[project_status] => 2
[approval_date] => 2012-02-08
[project_title] => Database Reporting
[project_type_id] => 3
[budget] => 100
[bidding_type_id] => 1
[employment_type_id] =>
[esl] => 1
[secrecy] => 0
[secrecy_file] =>
[description] => this is my first post
[performance] => 0
[cme] => 6
[files_share] =>
[project_deadline] => 1
[delivery_deadline] => 2012-02-16
[bidding_deadline] => 2012-02-27
[legal] => 1)Employer requires complete and fully-functional working program(s) in executable form as well as complete source code of all work done.
2) Deliverables must be in ready-to-run condition as follows (depending on the nature of the project and deliverables):
2a) If there are any server-side deliverables (intended to only exist in one place in the Employer's environment) then they must be installed by the Consultant in ready-to-run condition (unless specified elsewhere by the Employer).
2b) All other software (including but not limited to any desktop software or software the Employer intends to distribute) must include a software installation package that will install the software in ready-to-run condition on the platform(s) specified in this project (unless specified elsewhere by the Employer).
3) All deliverables will be considered 'work made for hire' under U.S. Copyright law. Employer will receive exclusive and complete copyrights to all work purchased.
3b) No part of the deliverable may contain any copyright restricted 3rd party components (including GPL, GNU, Copyleft, etc.) unless all copyright ramifications are explained AND AGREED TO by the Employer on the site per the Consultant's Worker Legal Agreement.
[close] => 0
[agree] => 1
[created] => 2012-02-06
[top_employer] => 0
[view_counter] => 41
[pause_deadline] =>
[payment_type_id] =>
[status_date] => 2012-02-08
[redeem_amount] =>
)
[User] => Array
(
[id] => 19
[username] => EmployerWarrior
[password] => 7c6a180b36896a0a8c02787eeafb0e4c
[account_type_id] => 2
[picture] =>
[resume] =>
[alert] => 0
[first_name] => Yaser
[last_name] => Ibrahim
[company_name] => Software Momentum, Inc.
[company_incorporated] => 1
[email] => Yaser43082#hotmail.com
[address] => 123 Somewhere
[apartment_number] =>
[city] => Some City
[state] => Some State
[country_id] => 1
[phone_city] => 614
[phone_country] => 1
[phone_number] => 1234567
[fax_city] =>
[fax_country] =>
[fax_number] =>
[instant_messenger_id] => 1
[im_username] =>
[postal] => 43082
[time_zone_id] => 58
[language_id] => 23
[esl] => 1
[us_resident] => 1
[ssnum] => 1234567
[have_ssnum] => 1
[work_permit_number] =>
[alien_number] =>
[work_permit] => 0
[green_card] => 0
[payment_type_id] => 4
[ip] =>
[created] => 2012-02-06 08:59:35
[top_employer] => 0
[top_consultant] => 0
[rating] => 0
[money_invested] => 0
[money_earned] => 0
[total_projects] => 0
[last_project] => 0
[active] => 0
[last_login] =>
[last_seen] => 2012-02-26 14:13:08
[is_logged_in] => 0
[time_format_id] => 1
[paypal_id] =>
[momentum_expiration] => 2014-02-12
)
[ProjectType] => Array
(
[id] => 3
[name] => Small Business Project
[min] => 100
[max] => 499.99
[order] => 4
)
[BiddingType] => Array
(
[id] => 1
[type] => Public Bidding
[percentage] => 15
)
[ProjectStatus] => Array
(
[id] => 2
[status] => Open Bids
[icon] => bid_open.png
[order] => 3
[default] => 1
)
[EmploymentType] => Array
(
[id] =>
[name] =>
)
[PaymentType] => Array
(
[id] =>
[type] =>
)
[BidWinner] => Array
(
[id] =>
[comment_group_id] =>
[bid_status_id] =>
[project_id] =>
[bid_amount] =>
[performance_guaranteed] =>
[isSmartBid] =>
[user_id] =>
[comment] =>
[isWinner] =>
[created] =>
)
[HRWWallet] => Array
(
[id] => 1
[user_id] => 19
[account_type_id] =>
[entity_id] => 1
[payment_type_id] => 1
[entity_type_id] => 1
[payment_to_id] =>
[payment_status_id] => 2
[payment_number] =>
[service_id] => 4
[created] => 2012-02-10 18:45:52
[description] => Payment for project
[credit] => 100
[debit] => 0
[billing_address] =>
[billing_city] =>
[billing_state] =>
[billing_country_id] =>
[billing_name] =>
[exp_year] =>
[exp_month] =>
[security_code] =>
)
[EmployerRating] => Array
(
[id] =>
[owner_id] =>
[project_id] =>
[rated_by_id] =>
[account_type_id] =>
[rating] =>
[comment] =>
[created] =>
)
[ConsultantRating] => Array
(
[id] =>
[owner_id] =>
[project_id] =>
[rated_by_id] =>
[account_type_id] =>
[rating] =>
[comment] =>
[created] =>
)
[Arbitration] => Array
(
[id] => 5
[project_id] => 1
[defendent_id] => 20
[plantiff_id] => 19
[magistrate_id] => 17
[arbitration_status_id] => 1
[verdict] =>
[created] => 2012-02-11 23:00:00
[end] =>
)
[Bid] => Array
(
[0] => Array
(
[id] => 1
[comment_group_id] => 1
[bid_status_id] => 1
[project_id] => 1
[bid_amount] => 75
[performance_guaranteed] => 10
[isSmartBid] => 0
[user_id] => 20
[comment] => Hi, I was writing about your project
[isWinner] =>
[created] => 2012-02-08 14:15:04
)
[1] => Array
(
[id] => 2
[comment_group_id] => 2
[bid_status_id] => 1
[project_id] => 1
[bid_amount] => 100
[performance_guaranteed] => 25
[isSmartBid] => 0
[user_id] => 18
[comment] => I can do this work
[isWinner] =>
[created] => 2012-02-08 14:16:39
)
[2] => Array
(
[id] => 5
[comment_group_id] => 2
[bid_status_id] => 1
[project_id] => 1
[bid_amount] => 45
[performance_guaranteed] => 10
[isSmartBid] => 1
[user_id] => 18
[comment] => This is a smart bid bid
[isWinner] => 0
[created] => 2012-02-25 15:40:54
)
)
[PaymentTransaction] => Array
(
[0] => Array
(
[id] => 1
[user_id] => 19
[account_type_id] =>
[entity_id] => 1
[payment_type_id] => 1
[entity_type_id] => 1
[payment_to_id] =>
[payment_status_id] => 2
[payment_number] =>
[service_id] => 4
[created] => 2012-02-10 18:45:52
[description] => Payment for project
[credit] => 100
[debit] => 0
[billing_address] =>
[billing_city] =>
[billing_state] =>
[billing_country_id] =>
[billing_name] =>
[exp_year] =>
[exp_month] =>
[security_code] =>
)
)
[WorkAcceptanceLog] => Array
(
)
[Comment] => Array
(
[0] => Array
(
[id] => 1
[comment_group_id] => 1
[project_id] => 1
[to_id] => 19
[from_id] => 20
[cc_id] =>
[isArbitration] =>
[no_contest] =>
[subject] => Re:
[comment] => Hi, I was writing about your project
[created] => 2012-02-08 14:15:04
[file_name] =>
[parent_id] =>
[last_message] =>
)
[1] => Array
(
[id] => 2
[comment_group_id] => 2
[project_id] => 1
[to_id] => 19
[from_id] => 18
[cc_id] =>
[isArbitration] =>
[no_contest] =>
[subject] => Re:
[comment] => I can do this work
[created] => 2012-02-08 14:16:39
[file_name] =>
[parent_id] =>
[last_message] =>
)
[2] => Array
(
[id] => 3
[comment_group_id] => 2
[project_id] => 1
[to_id] => 18
[from_id] => 19
[cc_id] =>
[isArbitration] =>
[no_contest] =>
[subject] => Broadcasted Message
[comment] => This is a broadcast to all consultants in regards to the project.
[created] => 2012-02-08 14:18:52
[file_name] =>
[parent_id] =>
[last_message] => 2012-02-08 14:18:51
)
[3] => Array
(
[id] => 4
[comment_group_id] => 1
[project_id] => 1
[to_id] => 20
[from_id] => 19
[cc_id] =>
[isArbitration] =>
[no_contest] =>
[subject] => Broadcasted Message
[comment] => This is a broadcast to all consultants in regards to the project.
[created] => 2012-02-08 14:18:52
[file_name] =>
[parent_id] =>
[last_message] => 2012-02-08 14:18:52
)
[4] => Array
(
[id] => 7
[comment_group_id] => 0
[project_id] => 1
[to_id] => 19
[from_id] => 27
[cc_id] => 20
[isArbitration] => 1
[no_contest] =>
[subject] => Arbitration
[comment] => What seems to be the issue ?
[created] => 2012-02-12 18:28:11
[file_name] =>
[parent_id] =>
[last_message] =>
)
[5] => Array
(
[id] => 8
[comment_group_id] => 5
[project_id] => 1
[to_id] => 17
[from_id] => 19
[cc_id] => 20
[isArbitration] => 1
[no_contest] =>
[subject] => Arbitration
[comment] => Well I would like to say I am not happy
[created] => 2012-02-12 19:35:51
[file_name] =>
[parent_id] =>
[last_message] =>
)
[6] => Array
(
[id] => 9
[comment_group_id] => 6
[project_id] => 1
[to_id] => 17
[from_id] => 19
[cc_id] => 20
[isArbitration] => 1
[no_contest] =>
[subject] => Arbitration
[comment] => I would like to make a complaint
[created] => 2012-02-12 22:07:08
[file_name] =>
[parent_id] =>
[last_message] =>
)
[7] => Array
(
[id] => 10
[comment_group_id] => 2
[project_id] => 1
[to_id] => 19
[from_id] => 18
[cc_id] =>
[isArbitration] =>
[no_contest] =>
[subject] => Re:Broadcasted Message
[comment] => This is a smart bid bid
[created] => 2012-02-25 15:40:54
[file_name] =>
[parent_id] =>
[last_message] =>
)
)
)
as you can see it ignores my attachment. what am i doing wrong.
This is a fairly old question, but for what its worth.
Here is the documentation for the Containable Behavior.
It states that, to load the behavior on the fly, you should use:
$this->Model->Behaviors->load('Containable');
I believe the difference is merely due to the fact that attach and detach have been deprecated.
Also, why not just set the $actAs property in your model, or even in AppModel?
class AppModel extends Model {
public $actAs = array('Containable');
// public $recursive = 0;
//...
}
The relation with the User model defined in the Project model is missing the foreignKey field, which may cause trouble. I assume Cake defaults that to user_id which should of course be the name of the column in the projects table.
Other than that, your use of the contain options seems ok.
Try this:
$this->Project->Behaviors->attach('Containable');
$this->Project->contain(array(
'conditions' => array('Project.id' => $projid),
'User'));
$project = $this->Project->find('first');
$this->Project->Behaviors->detach('Containable');

Categories