Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
Zdravím, narazil jsem na problém, s nímž si nevím rady. Netuším, zda to způsobují Rails či MySQL, hádám, že spíš to druhé bude pravdou...
Zde uvádím část kódu, který by se měl postarat o vygenerování tabulky. Nutno dodat, že jsem postupoval podle tohoto návodu:
class AddPlanningTable < ActiveRecord::Migration def self.up create_table :plans do |table| table.column :treatment_id, :integer, :limit => 10, :default => 0 table.column :name, :string end add_index "plans", ["treatment_id"], :name => "fk_plans_treatment" execute 'ALTER TABLE plans ADD CONSTRAINT fk_plans_treatment FOREIGN KEY ( treatment_id ) REFERENCES treatments( id )' end def self.down drop_table :plans end end
Po zadání rake migrate se ovšem dozvím následující:
(in /home/dau/development/) rake aborted! Mysql::Error: Can't create table './oncosys_dev/#sql-a96_ab.frm' (errno: 150): ALTER TABLE plans ADD CONSTRAINT fk_plans_treatment FOREIGN KEY ( treatment_id ) REFERENCES treatments( id )
Zajímavé je, že to tabulku vytvoří, nicméně Rails na to reagují zmateně a nelze ji pak pomocí Migrations odstranit.
Vše je bez problému jen v případě, že v definici nepoužiji generování cizího klíče - ovšem to je právě to, co nepotřebuji. Cizí klíč v tabulce musí být nutně definován. Stejná chybová hláška se objeví i v případě, že tabulku vygeneruji bez cizího klíče a pak se snažím jej přidat přímo v mysql. Přiznám se, že jsem zmaten a nevím si rady.
Nevíte někdo, co s tím? Bez vyřešení tohoto problému se nemůžu pohnout dál. Ještě bych dodal, že používám Gentoo Linux, MySQL v. 4.0.25, Rails 1.0.0.
Zahledal jsem na netu, chyba 105 nějakým způsobem opravdu souvisí s generováním cizího klíče, nicméně myslím, že všechny požadavky na indexy mám splněny. Pro pořádek ještě znovu udávám výpis struktury pár tabulek (s omezeným počtem hodnot):
CREATE TABLE machines ( id tinyint(3) unsigned NOT NULL auto_increment, name varchar(50) NOT NULL default '', kind_of_machine varchar(5) default NULL, PRIMARY KEY (id), UNIQUE KEY name (name) ) TYPE=InnoDB COMMENT='Table of machines'; -- -------------------------------------------------------- CREATE TABLE plans ( id int(11) NOT NULL auto_increment, treatment_id int(10) default '0', name varchar(255) default NULL, PRIMARY KEY (id), KEY treatment_id (treatment_id) ) TYPE=InnoDB; -- -------------------------------------------------------- CREATE TABLE treatments ( id int(10) unsigned NOT NULL auto_increment, patient_id int(10) unsigned default '0', machine_id tinyint(3) unsigned default '0', plan varchar(6) default NULL, description varchar(200) default NULL, PRIMARY KEY (id), KEY plan (plan), KEY machine_id (machine_id), KEY patient_id (patient_id) ) TYPE=InnoDB COMMENT='Basic table with treatments'; -- -- Omezení pro tabulku `treatments` -- ALTER TABLE `treatments` ADD CONSTRAINT `fk_treatments_machine` FOREIGN KEY (`machine_id`) REFERENCES `machines` (`id`), ADD CONSTRAINT `fk_treatments_patient` FOREIGN KEY (`patient_id`) REFERENCES `patients` (`id`);
Tiskni
Sdílej: