Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
K
KGOrders
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Cam Hayes
KGOrders
Commits
f1a2333b
Commit
f1a2333b
authored
Dec 16, 2024
by
Elias Sarraf
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
clean up code
parent
3ff5c8d6
Show whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
178 additions
and
555 deletions
+178
-555
.gitignore
.gitignore
+1
-1
View.Orders.pas
kgOrdersClient/View.Orders.pas
+17
-7
webKGOrders.dpr
kgOrdersClient/webKGOrders.dpr
+1
-1
Api.Database.dfm
kgOrdersServer/Source/Api.Database.dfm
+1
-1
Api.Database.pas
kgOrdersServer/Source/Api.Database.pas
+12
-56
Api.Server.Module.dfm
kgOrdersServer/Source/Api.Server.Module.dfm
+0
-2
Auth.Database.pas
kgOrdersServer/Source/Auth.Database.pas
+2
-48
Auth.Server.Module.dfm
kgOrdersServer/Source/Auth.Server.Module.dfm
+0
-1
Data.pas
kgOrdersServer/Source/Data.pas
+4
-4
Lookup.ServiceImpl.pas
kgOrdersServer/Source/Lookup.ServiceImpl.pas
+50
-57
Main.pas
kgOrdersServer/Source/Main.pas
+22
-5
rOrders.dfm
kgOrdersServer/Source/rOrders.dfm
+1
-106
rOrders.pas
kgOrdersServer/Source/rOrders.pas
+11
-11
uLibrary.pas
kgOrdersServer/Source/uLibrary.pas
+26
-228
kgOrdersServer.dpr
kgOrdersServer/kgOrdersServer.dpr
+24
-22
kgOrdersServer.dproj
kgOrdersServer/kgOrdersServer.dproj
+2
-2
kgOrdersServer.ini
kgOrdersServer/kgOrdersServer.ini
+4
-3
No files found.
.gitignore
View file @
f1a2333b
...
...
@@ -7,9 +7,9 @@ kgOrdersClient/css/__history/
kgOrdersClient/config/__history/
kgOrdersServer/__history
kgOrdersServer/__recovery
kgOrdersServer/*.log
kgOrdersServer/*.txt
kgOrdersServer/doc/
kgOrdersServer/logs
kgOrdersServer/Win32/
kgOrdersServer/Source/__history/
kgOrdersServer/Source/__recovery/
...
...
kgOrdersClient/View.Orders.pas
View file @
f1a2333b
...
...
@@ -78,7 +78,7 @@ type
procedure
orderEntry
(
orderInfo
,
customerInfo
,
mode
:
string
);
procedure
HideNotification
();
procedure
ShowNotification
(
Notification
:
string
);
procedure
Show
OrderList
Form
();
procedure
Show
AddOrder
Form
();
[
async
]
procedure
Search
(
searchOptions
:
string
);
[
async
]
procedure
GetOrders
(
searchOptions
:
string
);
[
async
]
procedure
getUser
();
...
...
@@ -126,7 +126,6 @@ begin
end
;
procedure
TFViewOrders
.
WebFormCreate
(
Sender
:
TObject
);
// Initializes important values:
// PageNumber: What page number the user is on IE 1: 1-10, 2: 11-20 etc
...
...
@@ -145,6 +144,7 @@ begin
getOrders
(
GenerateSearchOptions
());
end
;
procedure
TFViewOrders
.
WebFormShow
(
Sender
:
TObject
);
begin
console
.
log
(
info
);
...
...
@@ -154,6 +154,7 @@ begin
HideNotification
();
end
;
procedure
TFViewOrders
.
getUser
();
var
xdcResponse
:
TXDataClientResponse
;
...
...
@@ -167,6 +168,7 @@ begin
user
:=
TJSObject
(
data
[
0
]);
end
;
class
function
TFViewOrders
.
CreateForm
(
AElementID
,
Info
:
string
):
TWebForm
;
var
localInfo
:
string
;
...
...
@@ -184,7 +186,7 @@ begin
end
;
procedure
TFViewOrders
.
Show
OrderList
Form
();
procedure
TFViewOrders
.
Show
AddOrder
Form
();
var
newform
:
TFAddOrder
;
begin
...
...
@@ -208,8 +210,6 @@ begin
end
;
procedure
TFViewOrders
.
GeneratePagination
(
TotalPages
:
Integer
);
// Generates pagination for the table.
// TotalPages: Total amount of pages generated by the search
...
...
@@ -440,14 +440,16 @@ end;
procedure
TFViewOrders
.
btnAddOrderClick
(
Sender
:
TObject
);
begin
Show
OrderList
Form
();
Show
AddOrder
Form
();
end
;
procedure
TFViewOrders
.
orderEntry
(
orderInfo
,
customerInfo
,
mode
:
string
);
begin
FViewMain
.
ViewOrderEntry
(
orderInfo
,
customerInfo
,
mode
);
end
;
procedure
TFViewOrders
.
btnApplyClick
(
Sender
:
TObject
);
// Button that effectively functions as a GetOrders() button
var
...
...
@@ -465,16 +467,19 @@ begin
GetOrders
(
searchOptions
);
end
;
procedure
TFViewOrders
.
btnCloseNotificationClick
(
Sender
:
TObject
);
begin
HideNotification
();
end
;
procedure
TFViewOrders
.
btnConfirmClick
(
Sender
:
TObject
);
begin
//orderEntry('', 'ADD');
end
;
procedure
TFViewOrders
.
btnFiltersClick
(
Sender
:
TObject
);
var
filterSection
:
TJSHTMLElement
;
...
...
@@ -495,6 +500,7 @@ begin
end
;
end
;
procedure
TFViewOrders
.
Search
(
searchOptions
:
string
);
// Search method that searches the database for a specific phone number
var
...
...
@@ -525,12 +531,14 @@ begin
end
;
end
;
procedure
TFViewOrders
.
btnSearchClick
(
Sender
:
TObject
);
// orders Search method
begin
Search
(
edtSearch
.
Text
);
end
;
procedure
TFViewOrders
.
ClearTable
();
// clears the table
var
...
...
@@ -540,6 +548,7 @@ begin
tbody
.
innerHTML
:=
''
;
end
;
function
TFViewOrders
.
GenerateSearchOptions
():
string
;
// Generates searchOptions for GetOrders.
var
...
...
@@ -561,12 +570,14 @@ begin
Result
:=
searchOptions
;
end
;
procedure
TFViewOrders
.
HideNotification
;
begin
pnlMessage
.
ElementHandle
.
hidden
:=
True
;
info
:=
''
;
end
;
procedure
TFViewOrders
.
ShowNotification
(
Notification
:
string
);
begin
if
Notification
<>
''
then
...
...
@@ -597,5 +608,4 @@ begin
end
;
end
.
kgOrdersClient/webKGOrders.dpr
View file @
f1a2333b
...
...
@@ -67,5 +67,5 @@ begin
Application.MainFormOnTaskbar := True;
Application.CreateForm(TDMConnection, DMConnection);
DMConnection.InitApp(@StartApplication, @UnauthorizedAccessProc);
//
Application.Run;
Application.Run;
end.
kgOrdersServer/Source/
KGOrders
.Database.dfm
→
kgOrdersServer/Source/
Api
.Database.dfm
View file @
f1a2333b
object
KGOrdersDatabase: TKGOrders
Database
object
ApiDatabase: TApi
Database
OnCreate = DataModuleCreate
Height = 358
Width = 519
...
...
kgOrdersServer/Source/
KGOrders
.Database.pas
→
kgOrdersServer/Source/
Api
.Database.pas
View file @
f1a2333b
// Where the database is kept. Only used by Lookup.ServiceImpl to retrieve info
// from the data base and send it to the client.
// Author: ???
unit
KGOrders
.
Database
;
unit
Api
.
Database
;
interface
...
...
@@ -11,7 +11,7 @@ uses
Common
.
Logging
,
Vcl
.
Forms
,
MySQLUniProvider
;
type
T
KGOrders
Database
=
class
(
TDataModule
)
T
Api
Database
=
class
(
TDataModule
)
ucKG
:
TUniConnection
;
UniQuery1
:
TUniQuery
;
MySQLUniProvider1
:
TMySQLUniProvider
;
...
...
@@ -113,79 +113,35 @@ type
end
;
var
KGOrdersDatabase
:
TKGOrders
Database
;
ApiDatabase
:
TApi
Database
;
implementation
uses
uLibrary
;
{%CLASSGROUP 'Vcl.Controls.TControl'}
{$R *.dfm}
procedure
TKGOrdersDatabase
.
DataModuleCreate
(
Sender
:
TObject
);
var
iniFile
:
TIniFile
;
iniStr
:
string
;
procedure
TApiDatabase
.
DataModuleCreate
(
Sender
:
TObject
);
begin
Logger
.
Log
(
5
,
'TKGOrdersDatabase.DataModuleCreate'
);
iniFile
:=
TIniFile
.
Create
(
ExtractFilePath
(
Application
.
ExeName
)
+
'kgOrdersServer.ini'
);
try
Logger
.
Log
(
5
,
'--iniFile entries:'
);
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Server'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Server: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Server: '
+
iniStr
);
ucKG
.
Server
:=
iniStr
;
end
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Database'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Database: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Database: '
+
iniStr
);
ucKG
.
Database
:=
iniStr
;
end
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Username'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Username: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Username: '
+
iniStr
);
ucKG
.
Username
:=
iniStr
;
end
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Password'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Password: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Password: xxxxxxxx'
);
ucKG
.
Password
:=
iniStr
;
end
;
Logger
.
Log
(
3
,
'TApiDatabase.DataModuleCreate'
);
LoadDatabaseSettings
(
ucKG
,
'kgOrdersServer.ini'
);
try
ucKG
.
Connect
;
except
on
E
:
Exception
do
begin
Logger
.
Log
(
3
,
'--TKGOrdersDatabase.DataModuleCreate -Error connecting to database: '
+
E
.
Message
);
end
;
Logger
.
Log
(
3
,
'--TApiDatabase.DataModuleCreate -Error connecting to database: '
+
E
.
Message
);
end
;
Logger
.
Log
(
1
,
''
);
finally
iniFile
.
Free
;
end
;
end
;
class
procedure
T
KGOrders
Database
.
ExecSQL
(
const
SQL
:
string
);
class
procedure
T
Api
Database
.
ExecSQL
(
const
SQL
:
string
);
var
DB
:
T
KGOrders
Database
;
DB
:
T
Api
Database
;
begin
DB
:=
T
KGOrders
Database
.
Create
(
nil
);
DB
:=
T
Api
Database
.
Create
(
nil
);
try
DB
.
UniQuery1
.
SQL
.
Text
:=
SQL
;
DB
.
UniQuery1
.
ExecSQL
;
...
...
kgOrdersServer/Source/Api.Server.Module.dfm
View file @
f1a2333b
...
...
@@ -2,12 +2,10 @@ object ApiServerModule: TApiServerModule
Height = 273
Width = 230
object SparkleHttpSysDispatcher: TSparkleHttpSysDispatcher
Active = True
Left = 86
Top = 30
end
object XDataServer: TXDataServer
BaseUrl = 'http://localhost:2004/emsys/kgOrders/api/'
Dispatcher = SparkleHttpSysDispatcher
ModelName = 'Api'
EntitySetPermissions = <>
...
...
kgOrdersServer/Source/Auth.Database.pas
View file @
f1a2333b
...
...
@@ -38,50 +38,9 @@ uses
{$R *.dfm}
procedure
TAuthDatabase
.
DataModuleCreate
(
Sender
:
TObject
);
var
iniFile
:
TIniFile
;
iniStr
:
string
;
begin
Logger
.
Log
(
5
,
'TAuthDatabase.DataModuleCreate'
);
iniFile
:=
TIniFile
.
Create
(
ExtractFilePath
(
Application
.
ExeName
)
+
'kgOrdersServer.ini'
);
try
Logger
.
Log
(
5
,
'--iniFile entries:'
);
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Server'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Server: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Server: '
+
iniStr
);
ucKG
.
Server
:=
iniStr
;
end
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Database'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Database: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Database: '
+
iniStr
);
ucKG
.
Database
:=
iniStr
;
end
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Username'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Username: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Username: '
+
iniStr
);
ucKG
.
Username
:=
iniStr
;
end
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Password'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
5
,
'----Database->Password: Entry not found'
)
else
begin
Logger
.
Log
(
5
,
'----Database->Password: xxxxxxxx'
);
ucKG
.
Password
:=
iniStr
;
end
;
Logger
.
Log
(
3
,
'TAuthDatabase.DataModuleCreate'
);
LoadDatabaseSettings
(
ucKG
,
'kgOrdersServer.ini'
);
try
ucKG
.
Connect
;
except
...
...
@@ -90,11 +49,6 @@ begin
Logger
.
Log
(
3
,
'--TAuthDatabase.DataModuleCreate -Error connecting to database: '
+
E
.
Message
);
end
;
end
;
Logger
.
Log
(
1
,
''
);
finally
iniFile
.
Free
;
end
;
end
;
procedure
TAuthDatabase
.
DataModuleDestroy
(
Sender
:
TObject
);
...
...
kgOrdersServer/Source/Auth.Server.Module.dfm
View file @
f1a2333b
...
...
@@ -6,7 +6,6 @@ object AuthServerModule: TAuthServerModule
Top = 16
end
object XDataServer: TXDataServer
BaseUrl = 'http://localhost:2004/emsys/kgOrders/auth/'
Dispatcher = SparkleHttpSysDispatcher
ModelName = 'Auth'
EntitySetPermissions = <>
...
...
kgOrdersServer/Source/Data.pas
View file @
f1a2333b
...
...
@@ -14,7 +14,7 @@ uses
BaseGrid
,
AdvGrid
,
DBAdvGrid
,
MemDS
,
DBAccess
,
Uni
,
Vcl
.
StdCtrls
,
Vcl
.
Mask
,
vcl
.
wwdbedit
,
vcl
.
wwdotdot
,
vcl
.
wwdbcomb
,
REST
.
Client
,
REST
.
Types
,
System
.
JSON
,
System
.
Generics
.
Collections
,
AdvEdit
,
vcl
.
wwdblook
,
vcl
.
wwdbdatetimepicker
,
System
.
Hash
;
System
.
Hash
,
Api
.
Database
;
type
TFData
=
class
(
TForm
)
...
...
@@ -39,6 +39,7 @@ type
procedure
btnFindClick
(
Sender
:
TObject
);
procedure
btnPDFClick
(
Sender
:
TObject
);
private
kgDB
:
TApiDatabase
;
accountSID
:
string
;
authHeader
:
string
;
public
...
...
@@ -52,7 +53,7 @@ implementation
{$R *.dfm}
uses
KGOrders
.
Database
,
uLibrary
,
rOrders
;
uses
uLibrary
,
rOrders
;
procedure
TFData
.
btnPDFClick
(
Sender
:
TObject
);
begin
...
...
@@ -62,7 +63,7 @@ end;
procedure
TFData
.
FormCreate
(
Sender
:
TObject
);
begin
KGOrdersDatabase
:=
TKGOrders
Database
.
Create
(
Self
);
kgDB
:=
TApi
Database
.
Create
(
Self
);
end
;
procedure
TFData
.
btnFindClick
(
Sender
:
TObject
);
...
...
@@ -108,5 +109,4 @@ begin
end
;
end
.
kgOrdersServer/Source/Lookup.ServiceImpl.pas
View file @
f1a2333b
...
...
@@ -11,7 +11,7 @@ interface
uses
XData
.
Server
.
Module
,
XData
.
Service
.
Common
,
KGOrders
.
Database
,
Data
.
DB
,
frxClass
,
frxExportPDF
,
Api
.
Database
,
Data
.
DB
,
frxClass
,
frxExportPDF
,
Lookup
.
Service
,
System
.
Hash
,
System
.
JSON
,
Winapi
.
Windows
,
Winapi
.
Messages
,
System
.
SysUtils
,
System
.
Variants
,
System
.
Classes
,
Vcl
.
Graphics
,
Vcl
.
Controls
,
Vcl
.
Forms
,
Vcl
.
Dialogs
,
MemDS
,
DBAccess
,
Uni
,
hyiedefs
,
hyieutils
,
iexBitmaps
,
iesettings
,
iexLayers
,
iexRulers
,
...
...
@@ -25,7 +25,7 @@ type
[
ServiceImplementation
]
TLookupService
=
class
(
TInterfacedObject
,
ILookupService
)
strict
private
ordersDB
:
TKGOrders
Database
;
ordersDB
:
TApi
Database
;
private
function
GetItems
(
searchOptions
:
string
):
TItemList
;
function
GetUsers
(
searchOptions
:
string
):
TUserList
;
...
...
@@ -58,7 +58,7 @@ uses
procedure
TLookupService
.
AfterConstruction
;
begin
inherited
;
ordersDB
:=
T
KGOrders
Database
.
Create
(
nil
);
ordersDB
:=
T
Api
Database
.
Create
(
nil
);
end
;
...
...
@@ -154,13 +154,13 @@ begin
Result
.
data
.
Add
(
order
);
//TODO
end
;
ordersDB
.
UniQuery1
.
Close
;
SQL
:=
''
;
doQuery
(
ordersDB
.
UniQuery1
,
SQL
);
Result
.
count
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'total_count'
).
AsInteger
;
end
;
...
...
@@ -278,7 +278,7 @@ end;
function
TLookupService
.
generateSubQuery
(
filterType
,
statusType
,
currStatus
:
string
):
string
;
var
statusSuffix
:
string
;
statusSuffix
:
string
;
begin
result
:=
''
;
statusSuffix
:=
''
;
...
...
@@ -438,8 +438,6 @@ begin
SQL
:=
'Select colors_colors from corrugated_plate_orders where order_id = '
+
order
.
ID
;
end
;
doQuery
(
ordersDB
.
UniQuery2
,
SQL
);
colors
:=
ordersDB
.
UniQuery2
.
FieldByName
(
ColorType
).
AsString
;
order
.
colors
:=
colors
;
...
...
@@ -613,7 +611,6 @@ begin
else
result
.
proofing_art_approved_as_is
:=
false
;
result
.
proofing_approved_date
:=
ordersDB
.
UniQuery1
.
FieldByName
(
'proofing_approved_date'
).
AsString
;
end
else
begin
...
...
@@ -636,7 +633,6 @@ begin
//result.specialInstructions := ordersDB.UniQuery1.FieldByName('general_comments').AsString
end
;
function
TLookupService
.
GetItems
(
searchOptions
:
string
):
TItemList
;
var
params
:
TStringList
;
...
...
@@ -690,8 +686,8 @@ end;
function
TLookupService
.
GetUsers
(
searchOptions
:
string
):
TUserList
;
var
SQL
:
string
;
user
:
TUserItem
;
SQL
:
string
;
user
:
TUserItem
;
begin
if
searchOptions
=
''
then
SQL
:=
'select * from users order by NAME ASC'
...
...
@@ -729,22 +725,20 @@ end;
function
TLookupService
.
EditUser
(
const
editOptions
:
string
):
string
;
var
params
:
TStringList
;
user
:
string
;
password
:
string
;
full_name
:
string
;
status
:
string
;
email
:
string
;
access
:
string
;
rights
:
string
;
perspective
:
string
;
QB
:
string
;
SQL
:
string
;
newUser
:
string
;
hashString
:
string
;
hashPW
:
string
;
params
:
TStringList
;
user
:
string
;
password
:
string
;
full_name
:
string
;
status
:
string
;
email
:
string
;
access
:
string
;
rights
:
string
;
perspective
:
string
;
QB
:
string
;
SQL
:
string
;
newUser
:
string
;
hashString
:
string
;
hashPW
:
string
;
begin
params
:=
TStringList
.
Create
;
// parse the searchOptions
...
...
@@ -773,36 +767,35 @@ begin
//user.password := ordersDB.UniQuery1.FieldByName('PASSWORD').AsString;
if
(
not
(
newUser
.
IsEmpty
))
then
if
not
newUser
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'USER_NAME'
).
AsString
:=
newUser
;
if
(
not
(
full_name
.
IsEmpty
))
then
if
not
full_name
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'NAME'
).
AsString
:=
full_name
;
if
(
not
(
status
.
IsEmpty
))
then
if
not
status
.
IsEmpty
then
begin
if
(
StrToBool
(
status
)
)
then
if
StrToBool
(
status
)
then
ordersDB
.
UniQuery1
.
FieldByName
(
'STATUS'
).
AsString
:=
'ACTIVE'
else
ordersDB
.
UniQuery1
.
FieldByName
(
'STATUS'
).
AsString
:=
'INACTIVE'
end
;
if
(
not
(
email
.
IsEmpty
))
then
if
not
email
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'EMAIL'
).
AsString
:=
email
;
if
(
not
(
access
.
IsEmpty
))
then
if
not
access
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'ACCESS_TYPE'
).
AsString
:=
Access
;
if
(
not
(
rights
.
IsEmpty
))
then
if
not
rights
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'SYSTEM_RIGHTS'
).
AsInteger
:=
StrToInt
(
rights
);
if
(
not
(
perspective
.
IsEmpty
))
then
if
not
perspective
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'PERSPECTIVE_ID'
).
AsString
:=
perspective
;
if
(
not
(
QB
.
IsEmpty
))
then
if
not
QB
.
IsEmpty
then
ordersDB
.
UniQuery1
.
FieldByName
(
'QB_ID'
).
AsString
:=
QB
;
{if((not (Password = 'hidden')) and (not (Password.IsEmpty))) then
begin
hashString := ordersDB.UniQuery1.FieldByName('date_created').AsString + password;
...
...
@@ -886,6 +879,7 @@ begin
ordersDB
.
UniQuery1
.
FieldByName
(
'PRICE'
).
AsString
:=
'0'
else
ordersDB
.
UniQuery1
.
FieldByName
(
'PRICE'
).
AsString
:=
JSONData
.
GetValue
<
string
>(
'staff_fields_price'
);
ordersDB
.
UniQuery1
.
FieldByName
(
'JOB_NAME'
).
AsString
:=
JSONData
.
GetValue
<
string
>(
'staff_fields_job_name'
);
ordersDB
.
UniQuery1
.
FieldByName
(
'USER_ID'
).
AsString
:=
JSONData
.
GetValue
<
string
>(
'USER_ID'
);
ordersDB
.
UniQuery1
.
FieldByName
(
'LOCATION'
).
AsString
:=
JSONData
.
GetValue
<
string
>(
'staff_fields_art_location'
);
...
...
@@ -973,20 +967,20 @@ end;
function
TLookupService
.
AddUser
(
userInfo
:
string
):
string
;
var
user
:
string
;
password
:
string
;
full_name
:
string
;
status
:
string
;
email
:
string
;
access
:
string
;
rights
:
string
;
perspective
:
string
;
QB
:
string
;
SQL
:
string
;
dateCreated
:
TDateTime
;
hashString
:
string
;
hashPW
:
string
;
params
:
TStringList
;
user
:
string
;
password
:
string
;
full_name
:
string
;
status
:
string
;
email
:
string
;
access
:
string
;
rights
:
string
;
perspective
:
string
;
QB
:
string
;
SQL
:
string
;
dateCreated
:
TDateTime
;
hashString
:
string
;
hashPW
:
string
;
params
:
TStringList
;
begin
params
:=
TStringList
.
Create
;
params
.
StrictDelimiter
:=
true
;
...
...
@@ -1040,11 +1034,11 @@ end;
function
TLookupService
.
AddItem
(
itemInfo
:
string
):
string
;
var
params
:
TStringList
;
Name
:
string
;
Description
:
string
;
Status
:
boolean
;
SQL
:
string
;
params
:
TStringList
;
Name
:
string
;
Description
:
string
;
Status
:
boolean
;
SQL
:
string
;
begin
params
:=
TStringList
.
Create
;
params
.
StrictDelimiter
:=
true
;
...
...
@@ -1101,7 +1095,6 @@ begin
end
;
initialization
RegisterServiceType
(
TLookupService
);
...
...
kgOrdersServer/Source/Main.pas
View file @
f1a2333b
...
...
@@ -41,7 +41,7 @@ uses
Common
.
Logging
,
Common
.
Config
,
Sparkle
.
Utils
,
KGOrders
.
Database
,
Api
.
Database
,
Data
;
{$R *.dfm}
...
...
@@ -110,7 +110,7 @@ begin
try
Logger
.
Log
(
1
,
'iniFile: '
+
ExtractFilePath
(
Application
.
ExeName
)
+
'kgOrdersServer.ini'
);
Logger
.
Log
(
1
,
'LogLevels are displayed here. They were set in kgOrders.dpr, it executes first'
);
Logger
.
Log
(
1
,
'LogLevels are displayed here. They were set in kgOrders
Server
.dpr, it executes first'
);
iniStr
:=
iniFile
.
ReadString
(
'Settings'
,
'MemoLogLevel'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
1
,
'--Settings->memoLogLevel: Entry not found - default: 3'
)
...
...
@@ -130,11 +130,29 @@ begin
else
Logger
.
Log
(
1
,
'--Settings->LogFileNum: '
+
IntToStr
(
StrToInt
(
iniStr
)
-
1
)
);
Logger
.
Log
(
1
,
''
);
iniStr
:=
IniFile
.
ReadString
(
'Database'
,
'Server'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
1
,
'--Database->Server: Entry not found'
)
else
Logger
.
Log
(
1
,
'--Database->Server: '
+
iniStr
);
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Database'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
1
,
'----Database->Database: Entry not found'
)
else
Logger
.
Log
(
1
,
'----Database->Database: '
+
iniStr
);
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Username'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
1
,
'----Database->Username: Entry not found'
)
else
Logger
.
Log
(
1
,
'----Database->Username: '
+
iniStr
);
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Password'
,
''
);
if
iniStr
.
IsEmpty
then
Logger
.
Log
(
1
,
'----Database->Password: Entry not found'
)
else
Logger
.
Log
(
1
,
'----Database->Password: xxxxxxxx'
);
Logger
.
Log
(
1
,
''
);
finally
...
...
@@ -149,6 +167,8 @@ begin
AppServerModule
:=
TAppServerModule
.
Create
(
Self
);
AppServerModule
.
StartAppServer
(
serverConfig
.
url
);
UpdateGUI
;
end
;
procedure
TFMain
.
FormClose
(
Sender
:
TObject
;
var
Action
:
TCloseAction
);
...
...
@@ -160,9 +180,6 @@ begin
end
;
procedure
TFMain
.
UpdateGUI
;
const
cHttp
=
'http://+'
;
cHttpLocalhost
=
'http://localhost'
;
begin
if
AuthServerModule
.
SparkleHttpSysDispatcher
.
Active
then
memoInfo
.
Lines
.
Add
(
'AuthServer started at: '
+
AuthServerModule
.
XDataServer
.
BaseUrl
)
...
...
kgOrdersServer/Source/rOrders.dfm
View file @
f1a2333b
...
...
@@ -3,7 +3,7 @@ object rptOrders: TrptOrders
Height = 480
Width = 640
object frxOrders: TfrxReport
Version = '202
4.2.1
'
Version = '202
5.1.3
'
DotMatrixReport = False
IniFile = '\Software\Fast Reports'
PreviewOptions.Buttons = [pbPrint, pbLoad, pbSave, pbExport, pbZoom, pbFind, pbOutline, pbPageSetup, pbTools, pbEdit, pbNavigator, pbExportQuick, pbCopy, pbSelection]
...
...
@@ -1212,7 +1212,6 @@ object rptOrders: TrptOrders
Database = 'kg_order_entry'
Username = 'root'
Server = '192.168.102.130'
Connected = True
LoginPrompt = False
Left = 289
Top = 99
...
...
@@ -1242,7 +1241,6 @@ object rptOrders: TrptOrders
' 3 AS COLORS'
'FROM DUAL'
'')
Active = True
Left = 415
Top = 136
end
...
...
@@ -1258,108 +1256,5 @@ object rptOrders: TrptOrders
DataSetOptions = []
Left = 424
Top = 224
FieldDefs = <
item
FieldName = 'ORDER_ID'
end
item
FieldName = 'COMPANY_ID'
end
item
FieldName = 'USER_ID'
end
item
FieldName = 'ORDER_DATE'
FieldType = fftString
end
item
FieldName = 'START_DATE'
FieldType = fftDateTime
end
item
FieldName = 'END_DATE'
FieldType = fftDateTime
end
item
FieldName = 'ORDER_STATUS'
FieldType = fftString
end
item
FieldName = 'SCHED_JSON'
FieldType = fftString
Size = 4096
end
item
FieldName = 'LOCATION'
FieldType = fftString
end
item
FieldName = 'JOB_NAME'
FieldType = fftString
Size = 15
end
item
FieldName = 'COMPANY_NAME'
FieldType = fftString
Size = 14
end
item
FieldName = 'PROOF_DUE'
FieldType = fftString
Size = 16
end
item
FieldName = 'PROOF_DONE'
FieldType = fftString
Size = 16
end
item
FieldName = 'ART_DUE'
FieldType = fftString
end
item
FieldName = 'ART_DONE'
FieldType = fftString
Size = 16
end
item
FieldName = 'PLATE_DUE'
FieldType = fftString
Size = 16
end
item
FieldName = 'PLATE_DONE'
FieldType = fftString
Size = 16
end
item
FieldName = 'PRICE'
end
item
FieldName = 'QB_REF_NUM'
end
item
FieldName = 'MOUNT_DUE'
FieldType = fftString
Size = 16
end
item
FieldName = 'MOUNT_DONE'
FieldType = fftString
Size = 16
end
item
FieldName = 'SHIP_DUE'
FieldType = fftString
Size = 16
end
item
FieldName = 'SHIP_DONE'
FieldType = fftString
Size = 16
end
item
FieldName = 'COLORS'
end>
end
end
kgOrdersServer/Source/rOrders.pas
View file @
f1a2333b
...
...
@@ -16,6 +16,7 @@ type
frxReportTableObject1
:
TfrxReportTableObject
;
frxDBOrders
:
TfrxDBDataset
;
procedure
DataModuleCreate
(
Sender
:
TObject
);
private
public
...
...
@@ -29,21 +30,24 @@ var
implementation
uses
uLibrary
;
{%CLASSGROUP 'Vcl.Controls.TControl'}
{$R *.dfm}
procedure
TrptOrders
.
DataModuleCreate
(
Sender
:
TObject
);
var
iniFile
:
TIniFile
;
begin
// Load database connection settings from INI file
iniFile
:=
TIniFile
.
Create
(
ExtractFilePath
(
Application
.
ExeName
)
+
'kgOrdersServer.ini'
);
Logger
.
Log
(
3
,
'TAuthDatabase.DataModuleCreate'
);
LoadDatabaseSettings
(
ucKG
,
'kgOrdersServer.ini'
);
try
ucKG
.
Server
:=
iniFile
.
ReadString
(
'Database'
,
'Server'
,
''
);
ucKG
.
Connect
;
finally
iniFile
.
Free
;
except
on
E
:
Exception
do
begin
Logger
.
Log
(
3
,
'--TrptOrders.DataModuleCreate -Error connecting to database: '
+
E
.
Message
);
end
;
end
;
end
;
...
...
@@ -103,9 +107,5 @@ begin
end
;
end
.
kgOrdersServer/Source/uLibrary.pas
View file @
f1a2333b
...
...
@@ -5,46 +5,43 @@ interface
uses
System
.
Classes
,
Uni
;
const
ADD_REC_AUDIT_ENTRY
=
'0'
;
EDIT_REC_AUDIT_ENTRY
=
'1'
;
DEL_REC_AUDIT_ENTRY
=
'2'
;
REVIEW_REC_AUDIT_ENTRY
=
'3'
;
VIEW_REC_AUDIT_ENTRY
=
'4'
;
FIND_REC_AUDIT_ENTRY
=
'5'
;
PRINT_REC_AUDIT_ENTRY
=
'6'
;
OTHER_REC_AUDIT_ENTRY
=
'99'
;
function
GetServerTimeStamp
(
uq
:
TUniQuery
):
TDateTime
;
procedure
LoadDatabaseSettings
(
uc
:
TUniConnection
;
iniFilename
:
string
);
procedure
DoQuery
(
uq
:
TUniQuery
;
sql
:
string
);
function
CalculateAge
(
const
dob
,
dt
:
TDateTime
):
Integer
;
function
GetNextSeqVal
(
uq
:
TUniQuery
;
sequence
:
string
):
string
;
function
FormatNamePersonnel
(
uq
:
TUniQuery
;
format
:
string
):
string
;
function
FormatBkNum
(
bkNum
:
string
):
string
;
function
GetAssociatedNumber
(
uq
:
TUniQuery
;
numberType
:
string
):
string
;
function
FormatBookingAddress
(
uq
:
TUniQuery
;
format
:
string
):
string
;
function
SetMasterAuditEntry
(
uq
:
TUniQuery
;
const
entryId
,
auditType
,
linkId
,
agency
,
personnelId
,
recUser
,
details
,
searchKey
,
execSource
:
string
):
Boolean
;
function
SetDetailAuditEntry
(
uq
:
TUniQuery
;
const
entryId
,
title
,
auditType
:
string
;
auditList
:
TStringList
):
Boolean
;
function
GetOfficerName
(
agency
,
officer
:
string
;
uq
:
TUniQuery
):
string
;
function
GetRiciOfficerName
(
agency
,
officer
:
string
;
uq
:
TUniQuery
):
string
;
implementation
uses
System
.
SysUtils
,
System
.
IniFiles
,
Vcl
.
Forms
,
Data
.
DB
;
function
GetServerTimeStamp
(
uq
:
TUniQuery
):
TDateTime
;
procedure
LoadDatabaseSettings
(
uc
:
TUniConnection
;
iniFilename
:
string
)
;
var
sql
:
string
;
serverDateTime
:
TDateTime
;
iniFile
:
TIniFile
;
iniStr
:
string
;
begin
sql
:=
'select sysdate as currentdatetime from dual'
;
DoQuery
(
uq
,
sql
);
serverDateTime
:=
uq
.
FieldByName
(
'CURRENTDATETIME'
).
AsDateTime
;
uq
.
Close
;
Result
:=
serverDateTime
;
iniFile
:=
TIniFile
.
Create
(
ExtractFilePath
(
Application
.
ExeName
)
+
iniFilename
);
try
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Server'
,
''
);
if
not
iniStr
.
IsEmpty
then
uc
.
Server
:=
iniStr
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Database'
,
''
);
if
not
iniStr
.
IsEmpty
then
uc
.
Database
:=
iniStr
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Username'
,
''
);
if
not
iniStr
.
IsEmpty
then
uc
.
Username
:=
iniStr
;
iniStr
:=
iniFile
.
ReadString
(
'Database'
,
'Password'
,
''
);
if
not
iniStr
.
IsEmpty
then
uc
.
Password
:=
iniStr
;
finally
iniFile
.
Free
;
end
;
end
;
procedure
DoQuery
(
uq
:
TUniQuery
;
sql
:
string
);
...
...
@@ -82,204 +79,5 @@ begin
Result
:=
age
end
;
function
GetNextSeqVal
(
uq
:
TUniQuery
;
sequence
:
string
):
string
;
var
sql
:
string
;
begin
sql
:=
'select '
+
sequence
+
'.NEXTVAL as nextseqval from dual'
;
uq
.
Close
;
uq
.
SQL
.
Text
:=
sql
;
uq
.
Open
;
Result
:=
uq
.
FieldByName
(
'NEXTSEQVAL'
).
AsString
;
end
;
function
FormatNamePersonnel
(
uq
:
TUniQuery
;
format
:
string
):
string
;
var
leng
:
Integer
;
i
:
Integer
;
officerText
:
String
;
begin
leng
:=
Length
(
format
);
for
i
:=
0
to
leng
-
1
do
begin
case
format
[
i
+
1
]
of
'S'
:
officerText
:=
officerText
+
uq
.
FieldByName
(
'PF_LNAME'
).
AsString
;
'F'
:
if
not
uq
.
FieldByName
(
'PF_FNAME'
).
AsString
.
IsEmpty
then
officerText
:=
TrimRight
(
officerText
+
uq
.
FieldByName
(
'PF_FNAME'
).
AsString
)
;
'M'
:
if
not
uq
.
FieldByName
(
'PF_MI'
).
AsString
.
IsEmpty
then
officerText
:=
TrimRight
(
officerText
+
uq
.
FieldByName
(
'PF_MI'
).
AsString
);
','
:
officerText
:=
officerText
+
','
;
'.'
:
officerText
:=
officerText
+
'.'
;
' '
:
officerText
:=
officerText
+
' '
;
end
;
end
;
Result
:=
officerText
;
end
;
function
FormatBkNum
(
bkNum
:
string
):
string
;
var
bkNumStr
:
string
;
begin
bkNumStr
:=
bkNum
;
Result
:=
bkNumStr
.
Insert
(
4
,
'-'
);
end
;
function
GetAssociatedNumber
(
uq
:
TUniQuery
;
numberType
:
string
):
string
;
var
TLocateOptions
:
set
of
TLocateOption
;
begin
if
uq
.
Locate
(
'OTHER_AGENCY_CODE'
,
numberType
,
TLocateOptions
)
then
Result
:=
uq
.
FieldByName
(
'IDENTIFICATION'
).
AsString
end
;
function
FormatBookingAddress
(
uq
:
TUniQuery
;
format
:
string
):
string
;
var
addressText
:
AnsiString
;
leng
:
Integer
;
i
:
Integer
;
begin
leng
:=
Length
(
format
);
for
i
:=
0
to
leng
-
1
do
begin
case
format
[
i
+
1
]
of
'S'
:
begin
addressText
:=
addressText
+
uq
.
FieldByName
(
'STREET_NUM'
).
AsString
;
if
uq
.
FieldByName
(
'STREET_NUM_HALF'
).
AsString
=
'Y'
then
addressText
:=
addressText
+
' 1/2'
;
if
uq
.
FieldByName
(
'STREET_DIRECTION'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
uq
.
FieldByName
(
'STREET_DIRECTION'
).
AsString
;
if
uq
.
FieldByName
(
'STREET_NAME'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
TrimRight
(
uq
.
FieldByName
(
'STREET_NAME'
).
AsString
);
if
uq
.
FieldByName
(
'STREET_TYPE'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
TrimRight
(
uq
.
FieldByName
(
'STREET_TYPE'
).
AsString
);
if
uq
.
FieldByName
(
'APARTMENT_NUM'
).
AsString
<>
''
then
addressText
:=
addressText
+
' APT: '
+
TrimRight
(
uq
.
FieldByName
(
'APARTMENT_NUM'
).
AsString
);
end
;
'C'
:
if
uq
.
FieldByName
(
'CITY'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
TrimRight
(
uq
.
FieldByName
(
'CITY'
).
AsString
);
'T'
:
if
uq
.
FieldByName
(
'STATE'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
TrimRight
(
uq
.
FieldByName
(
'STATE'
).
AsString
);
'Z'
:
if
uq
.
FieldByName
(
'ZIP_CODE'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
TrimRight
(
uq
.
FieldByName
(
'ZIP_CODE'
).
AsString
);
'R'
:
if
uq
.
FieldByName
(
'COUNTRY'
).
AsString
<>
''
then
addressText
:=
addressText
+
' '
+
TrimRight
(
uq
.
FieldByName
(
'COUNTRY'
).
AsString
);
','
:
addressText
:=
addressText
+
','
;
'.'
:
addressText
:=
addressText
+
'.'
;
' '
:
addressText
:=
addressText
+
' '
;
end
;
end
;
Result
:=
addressText
;
end
;
function
SetMasterAuditEntry
(
uq
:
TUniQuery
;
const
entryId
,
auditType
,
linkId
,
agency
,
personnelId
,
recUser
,
details
,
searchKey
,
execSource
:
string
)
:
Boolean
;
var
sql
:
string
;
begin
sql
:=
'insert into auditmaster '
;
sql
:=
sql
+
'( AUDITMASTERID, SOURCEID, AUDITTYPE, AGENCY, PERSONNELID, RECUSER, RECDATE, DETAILS, SEARCHKEY, EXECSRC) '
;
sql
:=
sql
+
'values ('
;
sql
:=
sql
+
entryID
+
', '
;
sql
:=
sql
+
QuotedStr
(
linkID
)
+
', '
;
sql
:=
sql
+
QuotedStr
(
auditType
)
+
', '
;
sql
:=
sql
+
QuotedStr
(
agency
)
+
', '
;
sql
:=
sql
+
personnelid
+
', '
;
sql
:=
sql
+
QuotedStr
(
recUser
)
+
', '
;
sql
:=
sql
+
'sysdate, '
;
sql
:=
sql
+
QuotedStr
(
details
)
+
', '
;
sql
:=
sql
+
QuotedStr
(
searchKey
)
+
', '
;
sql
:=
sql
+
QuotedStr
(
execSource
)
+
')'
;
uq
.
Close
;
uq
.
SQL
.
Text
:=
sql
;
uq
.
Execute
;
uq
.
Close
;
Result
:=
True
;
end
;
function
SetDetailAuditEntry
(
uq
:
TUniQuery
;
const
entryId
,
title
,
auditType
:
string
;
auditList
:
TStringList
)
:
Boolean
;
var
i
:
Integer
;
sql
:
string
;
begin
for
i
:=
0
to
auditList
.
Count
-
1
do
begin
sql
:=
'insert into auditdetail values ('
;
sql
:=
sql
+
entryId
+
', '
;
sql
:=
sql
+
QuotedStr
(
auditList
.
Names
[
i
]
)
+
', '
;
sql
:=
sql
+
QuotedStr
(
''
)
+
', '
;
sql
:=
sql
+
QuotedStr
(
auditList
.
ValueFromIndex
[
i
]
)
+
', '
;
sql
:=
sql
+
auditType
+
')'
;
uq
.
Close
;
uq
.
SQL
.
Text
:=
sql
;
uq
.
Execute
;
uq
.
Close
;
end
;
Result
:=
True
;
end
;
function
GetOfficerName
(
agency
,
officer
:
string
;
uq
:
TUniQuery
):
string
;
var
sql
:
string
;
begin
if
agency
.
IsEmpty
or
officer
.
IsEmpty
then
Exit
;
sql
:=
'select a.agency_id, p.agency, p.pf_nameid, pf_lname, pf_fname, pf_mi, pf_badge '
;
sql
:=
sql
+
'from personnel p '
;
sql
:=
sql
+
'join agencycodes a on a.agency = p.agency '
;
sql
:=
sql
+
'where a.agency_id = '
+
agency
+
' and p.pf_nameid = '
+
officer
;
uq
.
Close
;
uq
.
SQL
.
Text
:=
sql
;
uq
.
Open
;
if
uq
.
IsEmpty
then
Result
:=
agency
+
'-'
+
officer
+
': not found'
else
begin
Result
:=
uq
.
FieldByName
(
'pf_lname'
).
AsString
+
', '
+
uq
.
FieldByName
(
'pf_fname'
).
AsString
;
Result
:=
Result
+
' '
+
uq
.
FieldByName
(
'pf_mi'
).
AsString
+
' ('
+
uq
.
FieldByName
(
'pf_badge'
).
AsString
+
')'
;
end
;
end
;
function
GetRiciOfficerName
(
agency
,
officer
:
string
;
uq
:
TUniQuery
):
string
;
var
sql
:
string
;
begin
if
agency
.
IsEmpty
or
officer
.
IsEmpty
then
Exit
;
sql
:=
'select * from rici.officer@rici_link where agency = '
+
agency
+
' and empno = '
+
QuotedStr
(
officer
);
uq
.
Close
;
uq
.
SQL
.
Text
:=
sql
;
uq
.
Open
;
if
uq
.
IsEmpty
then
Result
:=
agency
+
'-'
+
officer
+
': not found'
else
Result
:=
uq
.
FieldByName
(
'surname'
).
AsString
+
', '
+
uq
.
FieldByName
(
'given1'
).
AsString
+
' ('
+
uq
.
FieldByName
(
'empno'
).
AsString
+
')'
;
end
;
end
.
kgOrdersServer/kgOrdersServer.dpr
View file @
f1a2333b
...
...
@@ -9,7 +9,7 @@ uses
Api.Server.Module in 'Source\Api.Server.Module.pas' {ApiServerModule: TDataModule},
Main in 'Source\Main.pas' {FMain},
Common.Logging in 'Source\Common.Logging.pas',
KGOrders.Database in 'Source\KGOrders.Database.pas' {KGOrders
Database: TDataModule},
Api.Database in 'Source\Api.Database.pas' {Api
Database: TDataModule},
Common.Middleware.Logging in 'Source\Common.Middleware.Logging.pas',
Common.Config in 'Source\Common.Config.pas',
Auth.Server.Module in 'Source\Auth.Server.Module.pas' {AuthServerModule: TDataModule},
...
...
@@ -38,7 +38,7 @@ type
TFileLogAppender = class( TInterfacedObject, ILogAppender )
private
FLogLevel: Integer;
F
Filenam
e: string;
F
LogFil
e: string;
FCriticalSection: TCriticalSection;
public
constructor Create(ALogLevel: Integer; AFilename: string);
...
...
@@ -90,14 +90,18 @@ constructor TFileLogAppender.Create(ALogLevel: integer; AFilename: string);
var
iniFile: TIniFile;
fileNum: integer;
logsDir: string;
begin
FLogLevel := ALogLevel;
FCriticalSection := TCriticalSection.Create;
logsDir := ExtractFilePath(Application.ExeName) + 'logs\';
if not DirectoryExists(logsDir) then
CreateDir(logsDir);
iniFile := TIniFile.Create( ExtractFilePath(Application.ExeName) + 'kgOrdersServer.ini' );
try
fileNum := iniFile.ReadInteger( 'Settings', 'LogFileNum', 0 );
// FFilename := AFilename + Format('%.*d',[4, fileNum]);
FFilename := AFilename + Format('%.4d',[fileNum]);
FLogFile := logsDir + AFilename + Format( '%.4d', [fileNum] ) + '.log';
iniFile.WriteInteger( 'Settings', 'LogFileNum', fileNum + 1 );
finally
iniFile.Free;
...
...
@@ -112,35 +116,33 @@ end;
procedure TFileLogAppender.Send(logLevel: integer; Log: ILog);
var
FormattedMessage: string;
LogFile: string;
LogTime: TDateTime;
LogMsg: string;
FLogFile: TextFile;
formattedMessage: string;
logTime: TDateTime;
logMsg: string;
txtFile: TextFile;
begin
FCriticalSection.Acquire;
try
LogTime := Now;
LogFile := ExtractFilePath(Application.ExeName) + FFilename + '.log';
logTime := Now;
FormattedMessage := FormatDateTime('[yyyy-mm-dd HH:nn:ss.zzz]', L
ogTime);
L
ogMsg := Log.GetMessage;
if
L
ogMsg.IsEmpty then
F
ormattedMessage := ''
formattedMessage := FormatDateTime('[yyyy-mm-dd HH:nn:ss.zzz]', l
ogTime);
l
ogMsg := Log.GetMessage;
if
l
ogMsg.IsEmpty then
f
ormattedMessage := ''
else
FormattedMessage := FormattedMessage + '[' + IntToStr(logLevel) +'] ' + L
ogMsg;
formattedMessage := formattedMessage + '[' + IntToStr(logLevel) +'] ' + l
ogMsg;
try
AssignFile(
FLogFile,
LogFile );
if FileExists(LogFile) then
Append(
FLog
File )
AssignFile(
txtFile, F
LogFile );
if FileExists(
F
LogFile) then
Append(
txt
File )
else
ReWrite(
FLog
File );
ReWrite(
txt
File );
if logLevel <= FLogLevel then
WriteLn(
FLogFile, F
ormattedMessage );
WriteLn(
txtFile, f
ormattedMessage );
finally
CloseFile(
FLog
File);
CloseFile(
txt
File);
end;
finally
FCriticalSection.Release;
...
...
kgOrdersServer/kgOrdersServer.dproj
View file @
f1a2333b
...
...
@@ -133,8 +133,8 @@
<Form>FMain</Form>
</DCCReference>
<DCCReference Include="Source\Common.Logging.pas"/>
<DCCReference Include="Source\
KGOrders
.Database.pas">
<Form>
KGOrders
Database</Form>
<DCCReference Include="Source\
Api
.Database.pas">
<Form>
Api
Database</Form>
<FormType>dfm</FormType>
<DesignClass>TDataModule</DesignClass>
</DCCReference>
...
...
kgOrdersServer/kgOrdersServer.ini
View file @
f1a2333b
[Settings]
MemoLogLevel
=
5
FileLogLevel
=
5
LogFileNum
=
23
LogFileNum
=
30
webClientVersion
=
1.0.0
[Database]
--Server
=
192.168.159.132
Server
=
192.168.
198.131
Server
=
192.168.
60.129
--Server
=
192.168.75.133
--Database
=
--Username
=
--Password
=
Password
=
emsys!012
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment