campo-sirio/ba/ba1500.cpp

450 lines
11 KiB
C++
Executable File
Raw Blame History

#include <applicat.h>
#include <dongle.h>
#include <form.h>
#include <modaut.h>
#include <msksheet.h>
#include <printer.h>
#include <toolfld.h>
#include <utility.h>
#include <urldefid.h>
#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<67> che c'<27> 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;
}