Now disabling one language at a time manually might not be your cup of tea, so I would like to share a small job that disables all languages except the ones you want to keep enabled. Just create a new job and paste in the code below. Use at own risk of course, take backups and backups of the backups etc (you know the drill).
| 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
78 
79 
80 
81 
82 
83 
84 
85 
86 
87 
88 
89 
90 
91 
92 
93 
94 
95 
96 
97 
98 
99 | // Remove licence codes for unwanted languagesstaticvoidAdLanguageRemover(Args _args){    SysConfig                   sysConfig;    SysRemoveLicense            remLic;        Query                       query;    QueryBuildDataSource        qbd;    QueryBuildRange             qbr;    QueryRun                    queryRun;        FormRun                     confirmForm;    Set                         languagesToKeep = newSet(Types::String);    Set                         licenseCodeSet  = newSet(Types::Integer);    SetEnumerator               it;    intconfCount       = 0;    boolean                     licenseChanged  = false;    Args                        args            = newArgs(formStr(SysLicenseCompareForm));        boolean                     proceed         = false;    SysLicenseCodeDescription   codeDescription;    str                         currentLanguageId;    intpos, sysConfigId;            // List of languages to keep. Add, remove, change to fit your preference    languagesToKeep.add('nb-no');    languagesToKeep.add('en-us');    languagesToKeep.add('sv');    languagesToKeep.add('nl');    languagesToKeep.add('fr');    languagesToKeep.add('da');    languagesToKeep.add('de');            query = newQuery();    qbd = query.addDataSource(tableNum(sysConfig));        qbr = qbd.addRange(fieldNum(SysConfig,ConfigType));    qbr.value(enum2Value(ConfigType::AccessCodes));        qbr = qbd.addRange(fieldNum(SysConfig,Id));    qbr.value(SysLicenseCodeReadFile::rangeLanguage());        queryRun = newQueryRun(query);        delete_from remLic;            while(queryRun.next())    {        if(queryRun.changed(tableNum(sysConfig)))        {            sysConfig = queryRun.get(tableNum(sysConfig));        }                codeDescription     = SysLicenseCodeReadFile::codeDescription(sysConfig.Id);        pos                 = strFind(codeDescription,'(',strLen(codeDescription),-strLen(codeDescription));        currentLanguageId   = subStr(codeDescription,pos+1,strLen(codeDescription)-pos-1);                if(!languagesToKeep.in(currentLanguageId))        {            warning(strFmt('Removing language %1',SysLicenseCodeReadFile::codeDescription(sysConfig.Id)));            licenseCodeSet.add(sysConfig.Id);            remLic.clear();            remLic.LicenseCode = sysConfig.Id;            remLic.Description = SysLicenseCodeReadFile::codeDescription(sysConfig.Id);            remLic.insert();        }        else        {            info(strFmt('Keeping language %1',SysLicenseCodeReadFile::codeDescription(sysConfig.Id)));         }        }        if(licenseCodeSet.elements())    {        // if not valid code, then we should display the warning                    confCount   = SysLicenseCodeReadFile::findConfigKeysFromLicenseCodeSet(licenseCodeSet);        confirmForm = classfactory.formRunClass(args);        confirmForm.init();        confirmForm.run();                confirmForm.wait();                  if(confirmForm.closedOk())        {            it = licenseCodeSet.getEnumerator();            while(it.moveNext())            {                sysConfigId = it.current();                               update_recordSet sysConfig                     setting value = ''                    where sysConfig.id == sysConfigId;                            }                        SysLicenseCodeReadFile::codesModified();        }    }} | 
Allow for a synchronization to run through after the licenses are modified. Remember that this may impact the database schema, but if you really do not want the (ie.) Norwegian language to be enabled, it should be safe to disable. Thanks for reading!
 
 
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.