#include #include #include #include #include #include #include #include #include #include "ba1.h" #include "ba1500.h" #include "ba1500a.h" #include "ba1500b.h" #include "ba1600.h" /////////////////////////////////////////////////////////// TInformazione_moduli::TInformazione_moduli() : _unassigned_modules(0) { const TDongle& d = dongle(); for (word mod = BAAUT+1; mod < ENDAUT; mod++) { TToken_string t = d.module_code2desc(mod); if (t.len() > 2 && !t.starts_with("Modulo vario", true)) // Scarta moduli ignoti { if (d.shown(mod)) //controlla che sia veramente un modulo da mostrare! { t.add(d.module_code2name(mod)); t.add(mod); _infos.add(t); } } } _infos.sort(); for (int i = 0; i < _infos.items(); i++) { TToken_string& riga = _infos.row(i); const int mod = riga.get_int(2); _index[mod] = i; } } const char* TInformazione_moduli::get_description_by_order(int index) { if (index >= 0 && index < _infos.items()) return _infos.row(index).get(0); else return ""; } const char* TInformazione_moduli::get_description_by_name(const char* code) const { FOR_EACH_ARRAY_ROW_BACK(_infos, i, info) { if (xvt_str_compare_ignoring_case(info->get(1), code) == 0) return info->get(0); } return TR("{MODULO SCONOSCIUTO}"); } const char* TInformazione_moduli::get_name_by_order(int index) { if (index >= 0 && index < _infos.items()) return _infos.row(index).get(1); else return ""; } int TInformazione_moduli::get_module_by_order(int index) { if (index >= 0 && index < _infos.items()) return _infos.row(index).get_int(2); else return -1; } const char* TInformazione_moduli::get_description(int module) { return get_description_by_order(_index[module]); } const char* TInformazione_moduli::get_name(int module) { return get_name_by_order(_index[module]); } int TInformazione_moduli::get_index(int module) const { return _index[module]; } int TInformazione_moduli::get_index_by_name(const char* code) const { FOR_EACH_ARRAY_ROW_BACK(_infos, i, info) { if (xvt_str_compare_ignoring_case(info->get(1), code) == 0) break; } return i >= 0 ? get_index(i) : i; } /////////////////////////////////////////////////////////// // TForm richiesta attivazione /////////////////////////////////////////////////////////// class TRequest_form : public TForm { public: void update_serno(const TString& serno); void update_dongle(); void update_os(); void print_footer(); TRequest_form(const char* name); virtual ~TRequest_form() { } }; TRequest_form::TRequest_form(const char* name) : TForm(name) { const TPrint_section& header = section('H', odd_page); const TPrint_section& footer = section('F', odd_page); int riga[66]; int y1 = header.height()-2; int y2 = printer().formlen() - footer.height(); if ((y2-y1) & 0x1) y2--; // Forza un numero pari di righe for (int i = 0; ; i++) { riga[i] = y1 + 2*(i+1); if (riga[i] >= y2-1) { riga[i] = 0; break; } } genera_intestazioni(odd_page, y1+1); genera_fincatura(odd_page, y1, y2, riga); } void TRequest_form::update_serno(const TString& num) { const TDate today(TODAY); TForm_item& data = find_field('H', odd_page, FF_DATARICH); data.set(today.string()); find_field('H',odd_page,FF_DONGLE_HW).set("SSA"); TForm_item& serno = find_field('H', odd_page, FF_DONGLE_SN); serno.set(num); } void TRequest_form::update_dongle() { const TDongle& d = dongle(); TForm_item& year = find_field('H', odd_page, FF_YEAR); TString16 str; str << d.year_assist(); year.set(str); TForm_item& user = find_field('H', odd_page, FF_NUTENTI); str.format("%d", d.max_users()); user.set(str); } void TRequest_form::update_os() { char stros[256]; xvt_sys_get_version(stros, NULL, sizeof(stros)); TForm_item& os = find_field('H', odd_page, FF_OS); os.set(stros); } void TRequest_form::print_footer() { set_footer(odd_page, true); printer().formfeed(); } /////////////////////////////////////////////////////////// // TAttivazione_moduli /////////////////////////////////////////////////////////// class TAttivazione_moduli : public TSkeleton_application { TMask* _msk; TInformazione_moduli* _im; word _serno; word _wanted_users, _wanted_assist; private: void garble_dongle(word k[4]) const; const TString& garble_md5(const char* strin) const; const TString& garble_md5(long numin) const; protected: virtual bool create() ; virtual bool destroy() ; virtual void main_loop(); virtual bool use_files() const { return false; } virtual bool test_assistance_year() const; word& serno() { return _serno; } void init_mask(); int build_sheet(bool on = true); static void keyext(const TString & s, word * v); static void encode_second_key(); static bool k_notify(TSheet_field& f, int r, KEY k); static bool print_handler(TMask_field& fld, KEY key); static bool printlist_handler(TMask_field& fld, KEY key); static bool aga_handler(TMask_field& fld, KEY key); static bool sh_nposti_handler(TMask_field& fld, KEY key); static bool sh_acquisto_handler(TMask_field& fld, KEY key); static bool sh_aggiornamento_handler(TMask_field& fld, KEY key); protected: bool new_module_requested(); bool dongle_update_needed() const; void print_status(); public: virtual void print(); TAttivazione_moduli() : _msk(NULL), _wanted_users(0), _wanted_assist(0) { } virtual ~TAttivazione_moduli() { } }; HIDDEN TAttivazione_moduli& app() { return (TAttivazione_moduli&)main_app(); } int TAttivazione_moduli::build_sheet(bool on) { int nmod = 0; TSheet_field& sf = _msk->sfield(F_MODULI); for (int i = 0; i < _im->items(); i++) { TToken_string& riga = sf.row(i); riga = _im->get_description_by_order(i); riga.trim(); const int module = _im->get_module_by_order(i); const bool ics = module == 0 || (on && ::dongle().active(module)); if (ics) { riga.add("X"); if (module != 0) nmod++; else sf.disable_cell(i, -1); // Disabilita la riga della base } else riga.add(" "); riga.add(module); } return nmod; } void TAttivazione_moduli::garble_dongle(word k[4]) const { ::dongle().garble(k); } #define YEAR_MIN 2121 #define YEAR_MAX 2777 bool TAttivazione_moduli::print_handler(TMask_field& fld, KEY key) { if (key == K_SPACE) app().print(); return true; } bool TAttivazione_moduli::aga_handler(TMask_field& fld, KEY key) { if (key == K_SPACE) { TMask mask(TR("Dati Release"), 1, 80, 13); mask.add_string(101, 0, PR("Nome Breve "), 1, 1, 32); mask.add_string(102, 0, PR("Prodotto "), 1, 2, 32); mask.add_string(103, 0, PR("Distributore "), 1, 3, 60); mask.add_string(104, 0, PR("Amministratore "), 1, 4, 16, "U"); mask.add_string(105, 0, PR("Password "), 1, 5, 16, "*"); mask.add_button(DLG_OK, 0, "", -12, -1, 10, 2); mask.add_button(DLG_CANCEL, 0, "", -22, -1, 10, 2); //nuovo modo di gettare il producer da oem.ini TConfig oemini(CONFIG_OEM, "MAIN"); const int oem = oemini.get_int("OEM", NULL, -1, -1); if (oem >= 0) { TString8 para; para << "OEM_" << oem; oemini.set_paragraph(para); mask.set(101, ::decode(oemini.get("Name"))); mask.set(102, ::decode(oemini.get("Product"))); mask.set(103, ::decode(oemini.get("Reseller"))); mask.set(104, ::decode(oemini.get("Administrator"))); mask.set(105, ::decode(oemini.get("Password"))); } else //vecchio modo; già che c'è elimina i vecchi valori dall'install.ini { TConfig ini("install.ini", "Main"); mask.set(103, ::decode(ini.get("Producer"))); mask.set(104, ::decode(ini.get("Administrator"))); mask.set(105, ::decode(ini.get("Password"))); ini.remove("Producer"); ini.remove("Administrator"); ini.remove("Password"); } //setta comunque nel nuovo modo con producer = 0 se eventualmente ignoto if (mask.run() == K_ENTER) { oemini.set("Name", ::encode(mask.get(101))); oemini.set("Product", ::encode(mask.get(102))); oemini.set("Reseller", ::encode(mask.get(103))); oemini.set("Administrator", ::encode(mask.get(104))); oemini.set("Password", ::encode(mask.get(105))); if (oem < 0) oemini.set("OEM", "0", "MAIN", true); } } return true; } void TAttivazione_moduli::init_mask() { const TDate oggi(TODAY); const int nmod = build_sheet(); const TDongle& d = ::dongle(); _msk->set(F_SN, d.number()); _msk->set(F_USERS, d.max_users()); _msk->set(F_ASSIST, d.year_assist()); } bool TAttivazione_moduli::k_notify(TSheet_field& f, int r, KEY k) { if (k == K_INS || k == K_DEL) return false; return true; } void TAttivazione_moduli::print_status() { TRequest_form form("ba1500a"); TForm_item& descr = form.find_field('B', odd_page, 102); TForm_item& codice = form.find_field('B', odd_page, 103); form.find_field('H',odd_page,1).set(dongle().reseller()); form.update_serno(_msk->get(F_SN)); form.update_dongle(); form.update_os(); TWait_cursor hourglass; printer().open(); TSheet_field& sheet = _msk->sfield(F_MODULI); FOR_EACH_SHEET_ROW(sheet, r, row) { const int module = row->get_int(2) ; const bool active = ::dongle().active(module); if (!active) continue; descr.set(row->get(0)); codice.set(TR("*ATTIVO*")); form.print(-1); } printer().close(); } void TAttivazione_moduli::print() { print_status(); } // Questo programma non deve bloccarsi per l'anno di assistenza! bool TAttivazione_moduli::test_assistance_year() const { return true; } bool TAttivazione_moduli::dongle_update_needed() const { bool ok = TApplication::test_assistance_year(false); if (ok) { Tdninst dninst; const int dninst_year = dninst.assist_year(); const int dongle_year = dongle().year_assist(); ok = dninst_year <= dongle_year; } return !ok; } bool TAttivazione_moduli::create() { TDongle& d = dongle(); bool ok = d.login(true); if (!ok) return false; ok = !dongle_update_needed(); if (!ok) { ok = update_assistance_year(); if (ok && TApplication::test_assistance_year(false)) return false; // Aggiornamento automatico riuscito! } _im = new TInformazione_moduli; disable_menu_item(M_FILE_NEW); disable_menu_item(M_FILE_PG_SETUP); _msk = new TMask("ba1500a") ; _msk->set_handler(DLG_PRINT, print_handler); TSheet_field& sf = _msk->sfield(F_MODULI); sf.set_notify(k_notify); enable_menu_item(M_FILE_PG_SETUP); enable_menu_item(M_FILE_PRINT); return TSkeleton_application::create(); } bool TAttivazione_moduli::destroy() { if (_msk != NULL) delete _msk; if (_im != NULL) delete _im; return true; } void TAttivazione_moduli::main_loop() { init_mask(); _msk->run(); } int ba1500(int argc, char** argv) { TAttivazione_moduli a ; a.run(argc, argv, TR("Stato attivazione moduli")); return 0; }