diff --git a/classes/Policies.php b/classes/Policies.php
index de6a34471f..74a894f8e0 100644
--- a/classes/Policies.php
+++ b/classes/Policies.php
@@ -15,124 +15,32 @@
class Policies {
- /**
- * Policy Positions
- *
- * Array of all policy positions available to use.
- *
- * Arrays are in the form `{id} => {text}`
- */
-
- protected $policies = array(
- 363 => 'introducing foundation hospitals',
- 810 => 'greater regulation of gambling',
- 811 => 'smoking bans',
- 826 => 'equal gay rights',
- 837 => 'a wholly elected House of Lords',
- 975 => 'investigations into the Iraq war',
- 984 => 'replacing Trident with a new nuclear weapons system',
- 996 => 'a transparent Parliament',
- 1027 => 'a referendum on the UK\'s membership of the EU',
- 1030 => 'measures to prevent climate change',
- 1049 => 'the Iraq war',
- 1050 => 'the hunting ban',
- 1051 => 'introducing ID cards',
- 1052 => 'university tuition fees',
- 1053 => 'Labour\'s anti-terrorism laws',
- 1065 => 'more EU integration',
- 1071 => 'allowing ministers to intervene in inquests',
- 1074 => 'greater autonomy for schools',
- 1079 => 'removing hereditary peers from the House of Lords',
- 1084 => 'a more proportional system for electing MPs',
- 1087 => 'a stricter asylum system',
- 1105 => 'the privatisation of Royal Mail',
- 1109 => 'encouraging occupational pensions',
- 1110 => 'increasing the rate of VAT',
- 1113 => 'an equal number of electors per parliamentary constituency',
- 1120 => 'capping civil service redundancy payments',
- 1124 => 'automatic enrolment in occupational pensions',
- 1132 => 'raising England’s undergraduate tuition fee cap to £9,000 per year',
- 1136 => 'fewer MPs in the House of Commons',
- 6667 => 'the policies included in the 2010 Conservative - Liberal Democrat Coalition Agreement',
- 6670 => 'a reduction in spending on welfare benefits',
- 6671 => 'reducing central government funding of local government',
- 6672 => 'reducing housing benefit for social tenants deemed to have excess bedrooms (which Labour describe as the "bedroom tax")',
- 6673 => 'paying higher benefits over longer periods for those unable to work due to illness or disability',
- 6674 => 'raising welfare benefits at least in line with prices',
- 6676 => 'reforming the NHS so GPs buy services on behalf of their patients',
- 6677 => 'restricting the provision of services to private patients by the NHS',
- 6678 => 'greater restrictions on campaigning by third parties, such as charities, during elections',
- 6679 => 'reducing the rate of corporation tax',
- 6680 => 'raising the threshold at which people start to pay income tax',
- 6681 => 'increasing the tax rate applied to income over £150,000',
- 6682 => 'ending financial support for some 16-19 year olds in training and further education',
- 6683 => 'local councils keeping money raised from taxes on business premises in their areas',
- 6684 => 'making local councils responsible for helping those in financial need afford their council tax and reducing the amount spent on such support',
- 6685 => 'a banker’s bonus tax',
- 6686 => 'allowing marriage between two people of same sex',
- 6687 => 'academy schools',
- 6688 => 'use of UK military forces in combat operations overseas',
- 6690 => 'measures to reduce tax avoidance',
- 6691 => 'stronger tax incentives for companies to invest in assets',
- 6692 => 'slowing the rise in rail fares',
- 6693 => 'lower taxes on fuel for motor vehicles',
- 6694 => 'higher taxes on alcoholic drinks',
- 6695 => 'more powers for local councils',
- 6696 => 'the introduction of elected Police and Crime Commissioners',
- 6698 => 'fixed periods between parliamentary elections',
- 6699 => 'higher taxes on plane tickets',
- 6697 => 'selling England’s state owned forests',
- 6702 => 'spending public money to create guaranteed jobs for young people who have spent a long time unemployed',
- 6703 => 'laws to promote equality and human rights',
- 6704 => 'financial incentives for low carbon emission electricity generation methods',
- 6705 => 'requiring pub companies to offer pub landlords rent-only leases',
- 6706 => 'strengthening the Military Covenant',
- 6707 => 'restricting the scope of legal aid',
- 6708 => 'transferring more powers to the Senedd/Welsh Parliament',
- 6709 => 'transferring more powers to the Scottish Parliament',
- 6710 => 'culling badgers to tackle bovine tuberculosis',
- 6711 => 'an annual tax on the value of expensive homes (popularly known as a mansion tax)',
- 6715 => 'allowing national security sensitive evidence to be put before courts in secret sessions',
- 6716 => 'allowing employees to exchange some employment rights for shares in the company they work for',
- 6718 => 'restrictions on fees charged to tenants by letting agents',
- 6719 => 'limits on success fees paid to lawyers in no-win no fee cases',
- 6720 => 'a statutory register of lobbyists',
- 6721 => 'requiring the mass retention of information about communications',
- 6731 => 'more restrictive regulation of trade union activity',
- 6732 => 'allowing terminally ill people to be given assistance to end their life',
- 6733 => 'higher taxes on banks',
- 6734 => 'stronger enforcement of immigration rules',
- 6736 => 'a veto for MPs from England, Wales and Northern Ireland over laws specifically impacting their part of the UK',
- 6741 => 'greater regulation of hydraulic fracturing (fracking) to extract shale gas',
- 6753 => 'new high speed rail infrastructure',
- 6751 => 'mass surveillance of people’s communications and activities',
- 6764 => 'a right to remain for EU nationals already in living in the UK',
- 6761 => 'UK membership of the EU',
- 6758 => 'merging police and fire services under Police and Crime Commissioners',
- 6754 => 'reducing capital gains tax',
- 6747 => 'greater public control of bus services',
- 6746 => 'a publicly owned railway system',
- 6744 => 'phasing out secure tenancies for life',
- 6743 => 'charging a market rent to high earners renting a council home',
- 6757 => 'military action against ISIL (Daesh)',
- 842 => 'a lower voting age',
- );
-
private $commons_only = array(
811,
826,
1053,
);
- /**
- * Policy Sets
- *
- * Collections of policies (by ID number) to be used for sorted and
- * restricted displays.
- */
+ # policies where votes affected by covid voting restrictions
+ protected $covid_affected = [1136, 6860];
+
+ private $db;
- private $sets = array(
- 'summary' => array(
+ private $policy_id;
+
+ public function __construct($policy_id = null) {
+ $this->db = new \ParlDB;
+
+ if (TESTING) {
+ $policy_data = json_decode(file_get_contents(dirname(__FILE__) . '/../tests/policies.json'), true);
+ } else {
+ $policy_data = json_decode(file_get_contents(RAWDATA . '/scrapedjson/policies.json'), true);
+ }
+ $this->policies = $policy_data['policies'];
+ $this->set_descs = $policy_data['set_descs'];
+ $this->sets = $policy_data['sets'];
+
+ $this->sets['summary'] = array(
1113,
1136,
1132,
@@ -151,159 +59,7 @@ class Policies {
1079,
6671,
6672,
- ),
- 'social' => array(
- 826,
- 811,
- 1050,
- 6686,
- 6703,
- 6732,
- ),
- 'foreignpolicy' => array(
- 6688,
- 1049,
- 975,
- 984,
- 1065,
- 1027,
- 6706,
- 6764,
- 6761,
- 6757,
- ),
- 'welfare' => array(
- 6672,
- 6674,
- 6673,
- 6684,
- 6670,
- 6702,
- ),
- 'taxation' => array(
- 6680,
- 1110,
- 6694,
- 6699,
- 6693,
- 6681,
- 1109,
- 1124,
- 6685,
- 6733,
- 6711,
- 6716,
- 6731,
- 6754,
- ),
- 'business' => array(
- 6679,
- 6690,
- 6691,
- 6753,
- ),
- 'health' => array(
- 6677,
- 6676,
- 363,
- 811,
- 6732,
- ),
- 'education' => array(
- 1074,
- 1132,
- 6687,
- 6682,
- 1052
- ),
- 'reform' => array(
- 6671,
- 1113,
- 1136,
- 996,
- 1084,
- 837,
- 6683,
- 6678,
- 6698,
- 1079,
- 6708,
- 6709,
- 6695,
- 6736,
- 842,
- ),
- 'home' => array(
- 1087,
- 1071,
- 1051,
- 6696,
- 6721,
- 6734,
- 6751,
- 6758,
- ),
- 'environment' => array(
- 1030,
- 6693,
- 6697,
- 6699,
- 6704,
- 6710,
- 6741,
- 6753,
- ),
- 'transport' => array(
- 6747,
- 6692,
- 6693,
- 6699,
- 6746,
- ),
- 'housing' => array(
- 6744,
- 6743,
- ),
- 'misc' => array(
- 810,
- 1120,
- 1053,
- 1105,
- 6705,
- 6707,
- 6715,
- 6720,
- 6719,
- 6718,
- 6667,
- )
- );
-
- # policies where votes affected by covid voting restrictions
- protected $covid_affected = [1136, 6860];
-
- protected $set_descs = array(
- 'social' => 'Social Issues',
- 'foreignpolicy' => 'Foreign Policy and Defence',
- 'welfare' => 'Welfare and Benefits',
- 'taxation' => 'Taxation and Employment',
- 'business' => 'Business and the Economy',
- 'health' => 'Health',
- 'education' => 'Education',
- 'reform' => 'Constitutional Reform',
- 'home' => 'Home Affairs',
- 'environment' => 'Environmental Issues',
- 'transport' => 'Transport',
- 'housing' => 'Housing',
- 'misc' => 'Miscellaneous Topics',
- );
-
- private $db;
-
- private $policy_id;
-
- public function __construct($policy_id = null) {
- $this->db = new \ParlDB;
+ );
if ( $policy_id ) {
$this->policy_id = $policy_id;
diff --git a/scripts/json2db.pl b/scripts/json2db.pl
index 0199239971..6f567dfe81 100755
--- a/scripts/json2db.pl
+++ b/scripts/json2db.pl
@@ -24,9 +24,8 @@
use JSON::XS;
use LWP::Simple;
-use vars qw($motion_count $policy_count $align_count @policyids);
+use vars qw($motion_count $policy_count $align_count);
-require 'policyids.pl';
my $json = JSON::XS->new->latin1;
my $dsn = 'DBI:mysql:database=' . mySociety::Config::get('TWFY_DB_NAME'). ':host=' . mySociety::Config::get('TWFY_DB_HOST');
@@ -45,6 +44,8 @@
$motion_count = $policy_count = $align_count = 0;
+my $policyids = fetch_policies();
+
foreach my $dreamid ( @policyids ) {
my $policy_url = mySociety::Config::get('TWFY_VOTES_URL') . '/twfy-compatible/popolo/' . $dreamid . '.json';
my $policy_json = get($policy_url);
@@ -71,6 +72,33 @@
print "parsed $policy_count policies, $motion_count divisions, and $align_count alignments from JSON\n";
+# ---
+
+sub fetch_policies {
+ my $policies_url = mySociety::Config::get('TWFY_VOTES_URL') . '/policies/commons/active/all.json';
+ my $policies_json = get($policies_url);
+ my $policies = $json->decode($policies_json);
+
+ my @ids;
+ my $out = {};
+ foreach my $policy (@{$policies->{policies}}) {
+ say "Processing policy $policy->{id} $policy->{name}" if $verbose;
+ push @ids, $policy->{id};
+ foreach (@{$policy->{groups}}) {
+ push @{$out->{sets}{$_->{slug}}}, $policy->{id};
+ $out->{set_descs}{$_->{slug}} = $_->{name};
+ }
+ $out->{policies}{$policy->{id}} = $policy->{context_description};
+ }
+
+ $out = $json->encode($out);
+ open(my $fp, '>', mySociety::Config::get('RAWDATA') . '/scrapedjson/policies.json');
+ $fp->write($out);
+ close $fp;
+
+ return @ids;
+}
+
sub process_motions {
my ($aspects, $dreamid) = @_;
# Set AutoCommit off
diff --git a/scripts/policyids.pl b/scripts/policyids.pl
deleted file mode 100644
index d351654daa..0000000000
--- a/scripts/policyids.pl
+++ /dev/null
@@ -1,96 +0,0 @@
-@policyids = (
- 363,
- 810,
- 811,
- 826,
- 837,
- 975,
- 984,
- 996,
- 1027,
- 1030,
- 1049,
- 1050,
- 1051,
- 1052,
- 1053,
- 1065,
- 1071,
- 1074,
- 1079,
- 1084,
- 1087,
- 1105,
- 1109,
- 1110,
- 1113,
- 1120,
- 1124,
- 1132,
- 1136,
- 6667,
- 6670,
- 6671,
- 6672,
- 6673,
- 6674,
- 6676,
- 6677,
- 6678,
- 6679,
- 6680,
- 6681,
- 6682,
- 6683,
- 6684,
- 6685,
- 6686,
- 6687,
- 6688,
- 6690,
- 6691,
- 6692,
- 6693,
- 6694,
- 6695,
- 6696,
- 6697,
- 6698,
- 6699,
- 6702,
- 6703,
- 6704,
- 6705,
- 6706,
- 6707,
- 6708,
- 6709,
- 6710,
- 6711,
- 6715,
- 6716,
- 6718,
- 6719,
- 6720,
- 6721,
- 6731,
- 6732,
- 6733,
- 6734,
- 6736,
- 6741,
- 6753,
- 6751,
- 6764,
- 6761,
- 6758,
- 6754,
- 6747,
- 6746,
- 6744,
- 6743,
- 6757,
- 842,
-);
-
-1;
diff --git a/tests/policies.json b/tests/policies.json
new file mode 100644
index 0000000000..b95ecd4bd6
--- /dev/null
+++ b/tests/policies.json
@@ -0,0 +1,126 @@
+{
+ "set_descs":{
+ "housing": "Housing",
+ "health": "Health",
+ "welfare": "Welfare, Benefits and Pensions",
+ "transport": "Transport",
+ "environment": "Environmental Issues",
+ "social": "Social Issues",
+ "foreignpolicy": "Foreign Policy and Defence",
+ "business": "Business and the Economy",
+ "reform": "Constitutional Reform",
+ "taxation": "Taxation and Employment",
+ "home": "Home Affairs",
+ "education": "Education",
+ "misc": "Miscellaneous Topics"
+ },
+ "policies":{
+ "363": "introducing foundation hospitals",
+ "810": "greater regulation of gambling",
+ "811": "smoking bans",
+ "826": "equal gay rights",
+ "837": "a wholly elected House of Lords",
+ "842": "a lower voting age",
+ "975": "investigations into the Iraq war",
+ "984": "replacing Trident with a new nuclear weapons system",
+ "996": "a transparent Parliament",
+ "1027": "a referendum on the UK's membership of the EU",
+ "1030": "measures to prevent climate change",
+ "1049": "the Iraq war",
+ "1050": "the hunting ban",
+ "1051": "introducing ID cards",
+ "1052": "university tuition fees",
+ "1053": "Labour's anti-terrorism laws",
+ "1065": "more EU integration",
+ "1071": "allowing ministers to intervene in inquests",
+ "1074": "greater autonomy for schools",
+ "1079": "removing hereditary peers from the House of Lords",
+ "1084": "a more proportional system for electing MPs",
+ "1087": "a stricter asylum system",
+ "1105": "the privatisation of Royal Mail",
+ "1109": "encouraging occupational pensions",
+ "1110": "increasing the rate of VAT",
+ "1113": "an equal number of electors per parliamentary constituency",
+ "1120": "capping civil service redundancy payments",
+ "1124": "automatic enrolment in occupational pensions",
+ "1132": "raising England’s undergraduate tuition fee cap to £9,000 per year",
+ "1136": "fewer MPs in the House of Commons",
+ "6667": "the policies included in the 2010 Conservative - Liberal Democrat Coalition Agreement",
+ "6670": "a reduction in spending on welfare benefits",
+ "6671": "reducing central government funding of local government",
+ "6672": "reducing housing benefit for social tenants deemed to have excess bedrooms (which Labour describe as the \"bedroom tax\")",
+ "6673": "paying higher benefits over longer periods for those unable to work due to illness or disability",
+ "6674": "raising welfare benefits at least in line with prices",
+ "6676": "reforming the NHS so GPs buy services on behalf of their patients",
+ "6677": "restricting the provision of services to private patients by the NHS",
+ "6678": "greater restrictions on campaigning by third parties, such as charities, during elections",
+ "6679": "reducing the rate of corporation tax",
+ "6680": "raising the threshold at which people start to pay income tax",
+ "6681": "increasing the tax rate applied to income over £150,000",
+ "6682": "ending financial support for some 16-19 year olds in training and further education",
+ "6683": "local councils keeping money raised from taxes on business premises in their areas",
+ "6684": "making local councils responsible for helping those in financial need afford their council tax and reducing the amount spent on such support",
+ "6685": "a banker’s bonus tax",
+ "6686": "allowing marriage between two people of same sex",
+ "6687": "academy schools",
+ "6688": "use of UK military forces in combat operations overseas",
+ "6690": "measures to reduce tax avoidance",
+ "6691": "stronger tax incentives for companies to invest in assets",
+ "6692": "slowing the rise in rail fares",
+ "6693": "lower taxes on fuel for motor vehicles",
+ "6694": "higher taxes on alcoholic drinks",
+ "6695": "more powers for local councils",
+ "6696": "the introduction of elected Police and Crime Commissioners",
+ "6697": "selling England’s state owned forests",
+ "6698": "fixed periods between parliamentary elections",
+ "6699": "higher taxes on plane tickets",
+ "6702": "spending public money to create guaranteed jobs for young people who have spent a long time unemployed",
+ "6703": "laws to promote equality and human rights",
+ "6704": "financial incentives for low carbon emission electricity generation methods",
+ "6705": "requiring pub companies to offer pub landlords rent-only leases",
+ "6706": "strengthening the Military Covenant",
+ "6707": "restricting the scope of legal aid",
+ "6708": "transferring more powers to the Senedd/Welsh Parliament",
+ "6709": "transferring more powers to the Scottish Parliament",
+ "6710": "culling badgers to tackle bovine tuberculosis",
+ "6711": "an annual tax on the value of expensive homes (popularly known as a mansion tax)",
+ "6715": "allowing national security sensitive evidence to be put before courts in secret sessions",
+ "6716": "allowing employees to exchange some employment rights for shares in the company they work for",
+ "6718": "restrictions on fees charged to tenants by letting agents",
+ "6719": "limits on success fees paid to lawyers in no-win no fee cases",
+ "6720": "a statutory register of lobbyists",
+ "6721": "requiring the mass retention of information about communications",
+ "6731": "more restrictive regulation of trade union activity",
+ "6732": "allowing terminally ill people to be given assistance to end their life",
+ "6733": "higher taxes on banks",
+ "6734": "stronger enforcement of immigration rules",
+ "6736": "a veto for MPs from England, Wales and Northern Ireland over laws specifically impacting their part of the UK",
+ "6741": "greater regulation of hydraulic fracturing (fracking) to extract shale gas",
+ "6743": "charging a market rent to high earners renting a council home",
+ "6744": "phasing out secure tenancies for life",
+ "6746": "a publicly owned railway system",
+ "6747": "greater public control of bus services",
+ "6751": "mass surveillance of people’s communications and activities",
+ "6753": "new high speed rail infrastructure",
+ "6754": "reducing capital gains tax",
+ "6757": "military action against ISIL (Daesh)",
+ "6758": "merging police and fire services under Police and Crime Commissioners",
+ "6761": "UK membership of the EU",
+ "6764": "a right to remain for EU nationals already in living in the UK"
+ },
+ "sets":{
+ "housing": ["6743", "6744"],
+ "transport": ["6692", "6693", "6699", "6746", "6747"],
+ "environment": ["1030", "6693", "6697", "6699", "6704", "6710", "6741", "6753"],
+ "welfare": ["6670", "6672", "6673", "6674", "6684", "6702"],
+ "health": ["363", "811", "6676", "6677", "6732"],
+ "reform": ["837", "842", "996", "1079", "1084", "1113", "1136", "6671", "6678", "6683", "6695", "6698", "6708", "6709", "6736"],
+ "social": ["811", "826", "1050", "6686", "6703", "6732"],
+ "business": ["6679", "6690", "6691", "6753"],
+ "foreignpolicy": ["975", "984", "1027", "1049", "1065", "6688", "6706", "6757", "6761", "6764"],
+ "education": ["1052", "1074", "1132", "6682", "6687"],
+ "misc": ["810", "1053", "1105", "1120", "6667", "6705", "6707", "6715", "6718", "6719", "6720"],
+ "taxation": ["1109", "1110", "1124", "6680", "6681", "6685", "6693", "6694", "6699", "6711", "6716", "6731", "6733", "6754"],
+ "home": ["1051", "1071", "1087", "6696", "6721", "6734", "6751", "6758"]
+ }
+}