Column configuration public preview
PRODA ingests and standardizes hundreds of slight variations of thousands of variables. The rent roll grids in the PRODA application have long supported hundreds of slight variations of the standardized variables, via column configuration. The power of column configuration is now coming to the third party API’s query endpoint.
Some examples of how this can be used:
- “Lettable Area (sqm)” can be configured to “Lettable Area (tsubo)” or “Lettable Area (sqft)” if these units of measure suit you better.
- The API can return “Contracted Rent PA / sqft” instead you having to fetch “Contracted Rent PA” and “Lettable Area (sqm)” and converting and normalizing yourself.
- “Tenant Name” can be configured as “Tenant Name (incl. pre-let)”, which automatically returns the value for “Next Tenant Name” for vacant units.
For details on how to use this, please see the
query
endpoint documentation.
Column configuration is considered ALPHA. Feel free to experiment. If you do, please let us know anything we could improve. It is not suitable for production use yet and may change and break without notice.
Column removals
The following columns have been removed. Most of them have been deprecated for years. All of them have been deprecated since at least 2024.
_indexation_index_level_at_last_rent_adjustment
,
_rent_free_end_date
, _currency_deposit
,
_is_vat_applicable
, _rent_review_type
,
_notice_date_for_break_option
,
_walt_expiry
, _security_deposit_amount
,
_break_option_notice_period_information
,
_ground_rent_expense_pa
,
service_charge_cap_description
,
area_sqm_or_spaces
,
_has_break_option_been_exercised
,
_indexation_month
,
service_charge_expense_pa
,
_walt_first_break_expiry
,
indexation_fixed_percent
, _building_name
,
_floor
, currency_service_charge
,
_locality
, _region_level2
,
_region_level1
, gla_sqm
,
_lease_break_date
,
_lease_break_option_information
,
service_charge_income_pa
,
service_charge_information
,
_tenant_business_sector
,
_renewal_probability_percent
,
_building_id
,
_security_deposit_expiry_date
,
_automatic_lease_prolongation
,
_extension_option_holder
,
_rent_free_start_date
, _security_type
,
_security_required_amount
,
_rent_reduction_amount_pa
,
_has_competition_protection
,
_rent_amount_after_review
,
_rent_free_amount_pa
,
_lump_sum_operating_expense_income_pa
,
prepayment_operating_cost_income_pa
,
prepayment_heating_income_pa
,
_lease_expiry_notice_date
,
_lump_sum_cooling_income_pa
,
_lump_sum_electricity_income_pa
,
_lump_sum_heating_income_pa
,
_lump_sum_marketing_charge_income_pa
,
_lump_sum_other_recoverable_expense_income_pa
,
_lump_sum_waste_income_pa
,
_lump_sum_water_income_pa
,
prepayment_cooling_income_pa
,
prepayment_electricity_income_pa
,
prepayment_marketing_income_pa
,
prepayment_other_recoverable_income_pa
,
prepayment_waste_income_pa
,
prepayment_water_income_pa
,
_rentroll_date
, _property_id_user
,
_rentroll_id
,
lump_sum_operating_expense_income_pa
,
lump_sum_electricity_income_pa
,
lump_sum_heating_income_pa
,
lump_sum_marketing_charge_income_pa
,
lump_sum_other_recoverable_expense_income_pa
,
lump_sum_waste_income_pa
,
lump_sum_water_income_pa
,
_property_asset_class_source
,
property_acquisition_type
,
acquisition_date
, sale_date
,
number_of_rooms
, number_of_bedrooms
,
lettable_area_general
, erv_pm_sqm
,
vacancy_one_zero
,
has_competition_protection_one_zero
,
tenant_duns_number
,
_first_break_expiry_date
,
_tenant_has_exceptional_right_of_termination
,
_exceptional_right_of_termination_information
,
notice_period_for_lease_extension_option_months
,
lease_extension_length_months
,
extension_option_2_notice_period_months
,
extension_option_2_length_months
,
extension_option_3_notice_period_months
,
extension_option_3_length_months
,
extension_option_4_notice_period_months
,
extension_option_4_length_months
,
extension_option_five_notice_period_months
,
extension_option_five_length_months
,
contracted_rent_pm
,
_rent_review_start_date
,
rent_free_amount_pm
,
index_name_alternative
,
indexation_indexation_amount_pa
,
step_rent_1_new_rent_pm
,
step_rent_10_new_rent_pm
,
step_rent_2_new_rent_pm
,
step_rent_3_new_rent_pm
,
step_rent_4_new_rent_pm
,
step_rent_5_new_rent_pm
,
step_rent_6_new_rent_pm
,
step_rent_7_new_rent_pm
,
step_rent_8_new_rent_pm
,
step_rent_9_new_rent_pm
, turnover_rent_pm
,
additional_rent_pm
,
rent_reduction_amount_pm
,
has_rental_guarantee_zero_one
,
rental_guarantee_service_charge_component_ampunt_pa
,
estimated_turnover_pa
,
lump_sum_operating_cost_valid_from
,
lumpsum_operating_expense_valid_to
,
prepayment_operating_cost_valid_from
,
prepayment_operating_expense_currency
,
service_charge_cap_pa
,
prepayment_operating_heating_income_pa
,
lump_sum_operating_heating_income_pa
,
prepayment_operating_heating_income_pm
,
lump_sum_operating_heating_income_pm
,
lump_sum_operating_heating_income_valid_from
,
lump_sum_operating_heating_income_currency
,
prepayment_opearting_heating_income_valid_from
,
prepayment_heating_income_valid_from
,
prepayment_operating_heating_income_currency
,
marketing_charge_pm
,
prepayment_operating_expense_valid_to
,
vat_pm
, is_vat_applicable_one_zero
,
is_vat_applicable_rental_unit_one_zero
,
assupmtion_rent_pa_new_lease
,
service_charge_income_pm
,
heating_income_pm
,
lump_sum_operating_cost_income
,
lump_sum_heating_income
,
step_rent_1_new_rent_pp
,
step_rent_2_new_rent_pp
,
step_rent_3_new_rent_pp
,
step_rent_4_new_rent_pp
,
step_rent_5_new_rent_pp
,
step_rent_6_new_rent_pp
,
step_rent_7_new_rent_pp
,
step_rent_8_new_rent_pp
,
step_rent_9_new_rent_pp
,
step_rent_10_new_rent_pp
,
contracted_rent_pp
, vat_pp
,
marketing_charge_pp
,
prepayment_operating_heating_income_pp
,
lump_sum_operating_heating_income_pp
,
additional_rent_pp
,
rent_reduction_amount_pp
,
turnover_rent_pp
, erv_pm_sqm_unit
,
rent_roll_last_approved
, void_months
,
initial_lease_length_months
,
rent_free_months
, no_of_dock_doors
,
no_of_level_doors
,
initial_lease_length_years
,
rent_free_amount_pp
,
heating_income_fixed_pm
,
operating_expense_and_heating_income_fixed_pm
,
operating_expense_and_heating_income_fixed_pp
,
operating_expense_and_heating_income_pm
,
operating_expense_and_heating_income_pp
,
operating_expense_income_fixed_pm
,
housing_benefit_pm
,
housing_benefit_tenant_payable_pm
,
workbook_name
, washer_dryer_income_pm
,
employee_unit_reimbursement_pm
,
percent_area
, percent_rent
,
parent_comapny_id
,
notice_period_for_break_option_months
,
notice_period_for_break_option_two_months
,
break_option_3_notice_period_months
,
last_approved_by
,
net_maximum_legal_rent_pm
,
candidate_rentroll_id
,
dnb_maximun_credit_limit
,
dnb_maximun_credit_limit_currency
,
percentage_of_area
, percentage_of_rent
,
percentage_of_total_units
Minor JSON serialisation changes in query
endpoint
As a side effect of significant performance improvements to the query endpoint, the JSON serialisation of results will change in two minor ways. These are not considered breaking changes. An API client should not have relied on the previous behaviour.
TIMESTAMP columns will have values looking something like
"2017-11-15T10:10:00.58839+00:00"
rather than
"2017-11-15T10:10:00.58839Z"
. You should not rely on
this. As stated in the documentation, we consider any ISO8601
timestamp format acceptable.
The order of fields in response row objects will likely be different. You should not rely on any particular order, not even within the same response.
ENUM -> STRING
Please review the proposed changes and indicate to us whether or not you anticipate problems.
Problems with ENUMs
The column-list endpoint declares some columns as having columnType ENUM. These are not really any different from STRING columns. They do have explicit lists of possible values, but these change over time, which makes them not very useful.
Inconsistent values between API and PRODA application. Some ENUM
columns use machine representations of values, rather than
human-readable values. For example, the column
use_type_full
returns values such as
"OthDevelopmentLandAndSites"
instead of
"Development Land & Sites"
, like the PRODA
application.
The solution
We want to remove ENUM columns from the API entirely. There are two possible approaches: we can either go through a lengthy deprecation process, or we can just change the existing columns in place.
This is where you come in. Our documented stability promises rule out the easy way of changing columns in place. We would prefer to do it anyway, with your consent. The shortcut of changing columns in place worked well for the FLOAT -> INT changes in January. If you anticipate problems, please let us know, and we will work something out. If you do not anticipate problems, please let us know.
Concrete proposal
We will change the values returned by the following columns to match the values the PRODA application displays:
-
net_lease_type
,next_net_lease_type
rent_review_type
-
security_type
,security_type_two
,security_type_three
use_type_full
We will change all ENUM columns (listed below) to have columnType STRING instead:
-
break_option_holder
,extension_option_holder
,extension_option_holder_two
,extension_option_holder_three
,extension_option_holder_four
,extension_option_holder_five
,break_option_two_holder
,break_option_three_holder
indexation_threshold_unit_percent_or_points
-
net_lease_type
,next_net_lease_type
rent_review_type
-
security_type
,security_type_two
,security_type_three
tenure
-
turnover_rent_payment_frequency
,rent_payment_frequency
,headlease_payment_frequency
-
use_type_full_formatted
(we will also mark this as deprecated, since it will be the same asuse_type_full
) use_type_full
use_type
Feedback
Please let us know if you anticipate problems due to these changes.
Unit & Property Variable Updates
New variables added:
in_place_rent_pa
loan_provider
property_market
Existing variables modified:
unit_street
unit_street_number
unit_postcode
unit_city
unit_region
unit_country
New fields
We have added a new rentrolls
field to the
file details endpoint.
We have added a new originalFileId
field to the
list files endpoint.
We have changed the meaning of the
originalFileName
field in the
list files endpoint. It now refers to the name of the file that was originally
uploaded by the user, corresponding to the
originalFileId
field. We have added a new
fileName
field with the name of the current file.
Changes to column names and new variables
We have made several updates to our data schema, including changes to column names for clarity and the addition of new variables.
-
actual_lettable_area_sqm
: The name has been changed fromActual Lettable Area
toLettable Area
. -
contracted_lettable_area_sqm
: The name has been changed fromLettable Area
toContract Lettable Area
. privacy_level
: New variable.payer_type
: New variable.
File details endpoint
We have added a new file details endpoint.
List files endpoint
We have added a new list files endpoint.
FLOAT -> INT
We are planning on changing the column type of some variables from
FLOAT
to INT
. We said we would not change
column types, so this is technically a breaking change. However,
these variables were already integers. The JSON serialisation will
not change. We would like to make this change to improve consistency
and performance. We would like to skip the usual deprecation process
to avoid awkward variable names and creating more work for you with
repeated renamings on our end.
If you think you would be negatively affected by this change, please reach out to us. We have notified customers by email as well.
These are the variables that we are proposing to change:
parking_spaces
excel_row_index
unit_count
rent_payment_day
rentroll_id
parking_and_
lettable_area_unit_count
bicycle_parking_spaces
proda_portfolio_id
extraction_id
dnb_company_hierarchy_level
dnb_employee_count
dnb_company_risk_indicator
rent_free_outstanding_months
extension_options_count
occupied_unit_count
vacant_unit_count
non_revenue_unit_count
-
occupied_unit_count_excl_non_revenue_units
-
vacant_unit_count_excl_non_revenue_units
catella_parking_spaces
First INT columns
To maintain a more consistent naming convention across our API, we are updating the following variable names.
The new variables are the first to have
columnType: INT
. This column type has been documented
for a long time, but these are the first variables to actually use
it. If you're not handling this column type yet, you should start
now.
Variable additions:
proda_property_id
proda_project_id
Variable deprecations:
-
property_id
- useproda_property_id
instead -
project_id
- useproda_project_id
instead
Variable changes:
-
operating_expense_and_heating_income_fixed_pm
- Name change only. This variable was already deprecated and will be removed soon. -
operating_expense_and_heating_income_pm
- Name change only. This variable was already deprecated and will be removed soon.
Track Changes
Initial public preview of a new Track Changes endpoint. This enables API access to algorithmic Track Changes variables like "Reason for Rent Change".
This is an alpha release. The endpoint is subject to change without notice.
If this seems useful to you or if you have suggestions to make it even more useful, please let us know.