@dascompany/database 0.0.9 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/SQL.json CHANGED
@@ -40,8 +40,6 @@
40
40
  },
41
41
  "addresses": {
42
42
  "select": "SELECT id, country, city, postal_code, street, house_number, apartment_number FROM personal_information.addresses WHERE id = $id::BIGINT",
43
- "selectTypes": "SELECT type FROM personal_information.addresses WHERE account_id = $account_id::BIGINT",
44
- "selectId": "SELECT id FROM personal_information.addresses WHERE account_id = $account_id::BIGINT AND type = $type::SMALLINT",
45
43
  "insert": "INSERT INTO personal_information.addresses( id, country, city, postal_code, street, house_number, apartment_number) VALUES( $id::BIGINT, $country::TEXT, $city::TEXT, $postal_code::TEXT, $street::TEXT, $house_number::TEXT, $apartment_number::TEXT) ",
46
44
  "update": "UPDATE personal_information.addresses SET country = $country::TEXT, city = $city::TEXT, postal_code = $postal_code::TEXT , street = $street::TEXT , house_number = $house_number::TEXT , apartment_number = $apartment_number::TEXT WHERE id = $id::BIGINT",
47
45
  "selectNextId": "SELECT nextval('personal_information.addresses_id'::regclass)"
@@ -57,7 +55,6 @@
57
55
  "insert": "INSERT INTO personal_information.company_details( id, name, tax_number ) VALUES ($id::BIGINT, $name::TEXT, $tax_number::TEXT )",
58
56
  "update": "UPDATE personal_information.company_details SET name = $name::TEXT, tax_number = $tax_number::TEXT WHERE id = $id::BIGINT",
59
57
  "delete": "DELETE FROM personal_information.company_details WHERE id = $id::BIGINT",
60
- "selectIfIs": "SELECT FROM personal_information.company_details WHERE id = $id::BIGINT",
61
58
  "selectNextId": "SELECT nextval('personal_information.company_details_id'::regclass)"
62
59
  },
63
60
  "products": {
@@ -105,7 +102,7 @@
105
102
  "selectId": "SELECT id FROM files.files $WHERE",
106
103
  "selectAll": "SELECT f.id, f.name, f.orginal_name, f.catalog, f.size_kb, f.type, f.created_at FROM files.files as f $WHERE $ORDERBY",
107
104
  "select": "SELECT id, name, orginal_name, catalog, size_kb, type, created_at FROM files.files WHERE id = $id::BIGINT",
108
- "selectForConnection": "SELECT id, name, catalog, type FROM files.files JOIN files.file_connections ON file_id = id WHERE connection_type = $connection_type::TEXT AND connection_id = $connection_id::BIGINT ORDER BY sequence",
105
+ "selectForConnection": "SELECT id, name, catalog, type, sequence FROM files.files JOIN files.file_connections ON file_id = id WHERE connection_type = $connection_type::TEXT AND connection_id = $connection_id::BIGINT ORDER BY sequence",
109
106
  "selectNextId": "SELECT nextval('files.files_id'::regclass)",
110
107
  "insert": "INSERT INTO files.files( id, name, orginal_name, catalog, size_kb, type, created_at ) VALUES ( $id::BIGINT, $name::TEXT, $orginal_name::TEXT, $catalog::TEXT, $size_kb::BIGINT, $type::TEXT, now() )",
111
108
  "update": "UPDATE files.files SET name = $name::TEXT, orginal_name = $orginal_name::TEXT, catalog = $catalog::TEXT, size_kb = $size_kb::BIGINT, type = $type::TEXT WHERE id = $id::BIGINT ",
@@ -19,12 +19,10 @@ import DeliveryDetailsTable from './tables/personalInformation/DeliveryDetailsTa
19
19
  import DeliveryStatusesTable from './tables/personalInformation/DeliveryStatusesTable';
20
20
  import PaymentDetailsTable from './tables/orders/PaymentDetailsTable';
21
21
  import PaymentStatusesTable from './tables/orders/PaymentStatusesTable';
22
- import AdminAccountsTable from './tables/public/AdminAccountsTable';
23
22
  import StatusTypesTable from './tables/orders/StatusTypesTable';
24
23
  import CompanyDataTable from './tables/settings/CompanyDataTable';
25
24
  import FileConnectionsTable from './tables/files/FileConnectionsTable';
26
25
  export default class TableConnection extends Connection {
27
- private _AdminAccountsTable;
28
26
  private _StatusTypesTable;
29
27
  private _FilesTable;
30
28
  private _OrdersTable;
@@ -48,7 +46,6 @@ export default class TableConnection extends Connection {
48
46
  private _CompanyDataTable;
49
47
  private _FileConnectionsTable;
50
48
  constructor(pgClient: Client);
51
- get adminAccounts(): AdminAccountsTable;
52
49
  get statusTypes(): StatusTypesTable;
53
50
  get files(): FilesTable;
54
51
  get orders(): OrdersTable;
@@ -18,12 +18,10 @@ import DeliveryDetailsTable from './tables/personalInformation/DeliveryDetailsTa
18
18
  import DeliveryStatusesTable from './tables/personalInformation/DeliveryStatusesTable';
19
19
  import PaymentDetailsTable from './tables/orders/PaymentDetailsTable';
20
20
  import PaymentStatusesTable from './tables/orders/PaymentStatusesTable';
21
- import AdminAccountsTable from './tables/public/AdminAccountsTable';
22
21
  import StatusTypesTable from './tables/orders/StatusTypesTable';
23
22
  import CompanyDataTable from './tables/settings/CompanyDataTable';
24
23
  import FileConnectionsTable from './tables/files/FileConnectionsTable';
25
24
  export default class TableConnection extends Connection {
26
- _AdminAccountsTable;
27
25
  _StatusTypesTable;
28
26
  _FilesTable;
29
27
  _OrdersTable;
@@ -48,7 +46,6 @@ export default class TableConnection extends Connection {
48
46
  _FileConnectionsTable;
49
47
  constructor(pgClient) {
50
48
  super(pgClient);
51
- this._AdminAccountsTable = new AdminAccountsTable(this);
52
49
  this._StatusTypesTable = new StatusTypesTable(this);
53
50
  this._FilesTable = new FilesTable(this);
54
51
  this._OrdersTable = new OrdersTable(this);
@@ -72,9 +69,6 @@ export default class TableConnection extends Connection {
72
69
  this._CompanyDataTable = new CompanyDataTable(this);
73
70
  this._FileConnectionsTable = new FileConnectionsTable(this);
74
71
  }
75
- get adminAccounts() {
76
- return this._AdminAccountsTable;
77
- }
78
72
  get statusTypes() {
79
73
  return this._StatusTypesTable;
80
74
  }
package/dist/index.d.ts CHANGED
@@ -1,71 +1,89 @@
1
1
  import DatabaseConnection from "./DatabaseConnection";
2
2
  import StockObject from "./types/StockObject";
3
3
  import StockObjectMapper from "./types/StockObjectMapper";
4
- import AddressesReader from "./reader/AddressesReader";
4
+ import Table from "./Table";
5
+ import Query from "./query/Query";
6
+ import TableConnection from './TableConnection';
7
+ import ParameterType from './types/parameters/ParameterType';
8
+ import ParameterFilter from './types/parameters/ParameterFilter';
9
+ import ConnectorE from './types/ConnectorE';
10
+ import ParameterI from './types/ParameterI';
11
+ import QueryOptionsI from './types/QueryOptionsI';
12
+ import ResultLimitationI from './types/ResultLimitationI';
13
+ import Parameters from './utils/Parameters';
14
+ import OrderByI from "./utils/OrderByI";
15
+ import QueryOptions from './query/QueryOptions';
16
+ import Client from "./stockObjects/Client";
17
+ import ClientAccountRepo from "./repo/ClientAccountRepo";
5
18
  import ClientAccountReader from "./reader/ClientAccountReader";
6
- import CompanyDetailsReader from "./reader/CompanyDetailsReader";
7
- import ContactDetailsReader from "./reader/ContactDetailsReader";
8
- import DeliveryDetailsReader from "./reader/DeliveryDetailsReader";
9
- import DeliveryMethodReader from "./reader/DeliveryMethodReader";
10
- import InvoiceDetailsReader from "./reader/InvoiceDetailsReader";
11
- import OrderProductsReader from "./reader/OrderProductsReader";
12
- import OrderReader from "./reader/OrderReader";
13
- import FilesReader from './reader/FilesReader';
14
- import OrderStatusReader from "./reader/OrderStatusReader";
15
- import OrderStatusRepo from "./repo/OrderStatusRepo";
16
- import PaymentDetailsReader from "./reader/payment/PaymentDetailsReader";
17
- import PaymentMethodReader from "./reader/payment/PaymentMethodReader";
18
- import PaymentStatusesReader from "./reader/payment/PaymentStatusesReader";
19
- import PersonalDataReader from "./reader/PersonalDataReader";
20
- import ProductReader from "./reader/ProductReader";
19
+ import Address from "./stockObjects/Address";
20
+ import AddressI from "./types/AddressI";
21
21
  import AddressesRepo from "./repo/AddressesRepo";
22
- import ClientAccountRepo from "./repo/ClientAccountRepo";
23
- import CompanyDetailsRepo from "./repo/CompanyDetailsRepo";
24
- import CompanyDataRepo from "./repo/CompanyDataRepo";
25
- import ContactDetailsRepo from "./repo/ContactDetailsRepo";
26
- import DeliveryDetailsRepo from "./repo/DeliveryDetailsRepo";
27
- import InvoiceDetailsRepo from "./repo/InvoiceDetailsRepo";
28
- import OrderRepo from "./repo/OrderRepo";
29
- import PaymentDetailsRepo from "./repo/PaymentDetailsRepo";
22
+ import AddressesReader from "./reader/AddressesReader";
23
+ import PersonalData from "./stockObjects/PersonalData";
30
24
  import PersonalDataRepo from "./repo/PersonalDataRepo";
31
- import PaymentMethodRepo from './repo/PaymentMethodRepo';
32
- import ProductRepo from "./repo/ProductRepo";
33
- import Address from "./stockObjects/Address";
34
- import Admin from "./stockObjects/Admin";
25
+ import PersonalDataReader from "./reader/PersonalDataReader";
26
+ import PersonalDataI from "./types/PersonalDataI";
35
27
  import CompanyDetails from "./stockObjects/CompanyDetails";
28
+ import CompanyDetailsRepo from "./repo/CompanyDetailsRepo";
29
+ import CompanyDetailsReader from "./reader/CompanyDetailsReader";
30
+ import CompanyDetailsI from "./types/CompanyDetailsI";
36
31
  import ContactDetails from "./stockObjects/ContactDetails";
32
+ import ContactDetailsRepo from "./repo/ContactDetailsRepo";
33
+ import ContactDetailsReader from "./reader/ContactDetailsReader";
34
+ import ContactDetailsI from "./types/ContactDetailsI";
37
35
  import DeliveryDetails from "./stockObjects/DeliveryDetails";
36
+ import DeliveryDetailsRepo from "./repo/DeliveryDetailsRepo";
37
+ import DeliveryDetailsReader from "./reader/DeliveryDetailsReader";
38
+ import DeliveryDetailsI from "./types/DeliveryDetailsI";
39
+ import DeliveryMethods from "./stockObjects/DeliveryMethods";
40
+ import DeliveryMethodRepo from './repo/DeliveryMethodRepo';
41
+ import DeliveryMethodReader from "./reader/DeliveryMethodReader";
42
+ import DeliveryMethodI from "./types/DeliveryMethodI";
38
43
  import DeliveryStatus from "./stockObjects/DeliveryStatus";
44
+ import DeliveryStatusReader from './reader/DeliveryStatusReader';
39
45
  import InvoiceDetails from "./stockObjects/InvoiceDetails";
40
- import Order from "./stockObjects/Order";
41
- import OrderProduct from "./stockObjects/OrderProduct";
46
+ import InvoiceDetailsRepo from "./repo/InvoiceDetailsRepo";
47
+ import InvoiceDetailsReader from "./reader/InvoiceDetailsReader";
48
+ import InvoiceDetailsI from "./types/InvoiceDetailsI";
42
49
  import PaymentDetails from "./stockObjects/PaymentDetails";
50
+ import PaymentDetailsRepo from "./repo/PaymentDetailsRepo";
51
+ import PaymentDetailsReader from "./reader/payment/PaymentDetailsReader";
52
+ import PaymentDetailsI from "./types/PaymentDetailsI";
53
+ import PaymentMethods from "./stockObjects/PaymentMethods";
54
+ import PaymentMethodRepo from './repo/PaymentMethodRepo';
55
+ import PaymentMethodReader from "./reader/payment/PaymentMethodReader";
56
+ import PaymentMethodE from "./types/PaymentMethodE";
57
+ import PaymentMethodI from "./types/PaymentMethodI";
43
58
  import PaymentStatus from "./stockObjects/PaymentStatus";
44
- import PersonalData from "./stockObjects/PersonalData";
45
- import Product from "./stockObjects/Product";
46
- import Status from "./stockObjects/Status";
47
- import Client from "./stockObjects/Client";
48
- import AdminRepo from './repo/AdminRepo';
49
- import TableConnection from './TableConnection';
50
- import ParameterType from './types/parameters/ParameterType';
51
- import DeliveryStatusReader from './reader/DeliveryStatusReader';
52
- import ConnectorE from './types/ConnectorE';
53
- import ParameterI from './types/ParameterI';
54
- import QueryOptionsI from './types/QueryOptionsI';
55
- import ResultLimitationI from './types/ResultLimitationI';
56
- import ParameterFilter from './types/parameters/ParameterFilter';
59
+ import PaymentStatusesReader from "./reader/payment/PaymentStatusesReader";
57
60
  import PaymentStatusE from './types/PaymentStatusE';
61
+ import Order from "./stockObjects/Order";
62
+ import OrderRepo from "./repo/OrderRepo";
63
+ import OrderReader from "./reader/OrderReader";
64
+ import OrderProduct from "./stockObjects/OrderProduct";
65
+ import OrderProductsRepo from "./repo/OrderProductsRepo";
66
+ import OrderProductsReader from "./reader/OrderProductsReader";
58
67
  import OrderProductI from './types/OrderProductI';
59
- import Parameters from './utils/Parameters';
60
- import DeliveryMethodRepo from './repo/DeliveryMethodRepo';
61
- import StatusTypesReader from './reader/StatusTypesReader';
62
- import FileConnectionsReader from "./reader/FileConnectionsReader";
63
- import FileConnectionsRepo from "./repo/FileConnectionsRepo";
64
- import CompanyDataReader from "./reader/CompanyDataReader";
65
- import OrderByI from "./utils/OrderByI";
66
- import FilesRepo from './repo/FilesRepo';
68
+ import Status from "./stockObjects/Status";
69
+ import OrderStatusRepo from "./repo/OrderStatusRepo";
70
+ import OrderStatusReader from "./reader/OrderStatusReader";
71
+ import StatusI from "./types/StatusI";
72
+ import ProductI from './types/ProductI';
73
+ import Product from "./stockObjects/Product";
74
+ import ProductRepo from "./repo/ProductRepo";
75
+ import ProductReader from "./reader/ProductReader";
67
76
  import File from './stockObjects/File';
68
- import QueryOptions from './query/QueryOptions';
69
- import OrderProductsRepo from "./repo/OrderProductsRepo";
77
+ import FilesRepo from './repo/FilesRepo';
78
+ import FilesReader from './reader/FilesReader';
79
+ import FileI from "./types/FileI";
80
+ import FileConnection from "./stockObjects/FileConnection";
81
+ import FileConnectionsRepo from "./repo/FileConnectionsRepo";
82
+ import FileConnectionsReader from "./reader/FileConnectionsReader";
70
83
  import FileConnectionTypeE from './types/FileConnectionTypeE';
71
- export { TableConnection, StockObject, StockObjectMapper, DatabaseConnection, File, OrderByI, ParameterType, ConnectorE, FileConnectionTypeE, PaymentStatusE, Parameters, ParameterI, QueryOptions, QueryOptionsI, ResultLimitationI, OrderProductI, ParameterFilter, PaymentDetailsReader, FilesReader, PaymentMethodReader, DeliveryStatusReader, PaymentStatusesReader, AddressesReader, ClientAccountReader, CompanyDetailsReader, ContactDetailsReader, DeliveryDetailsReader, DeliveryMethodReader, InvoiceDetailsReader, OrderProductsReader, OrderReader, OrderStatusReader, PersonalDataReader, ProductReader, StatusTypesReader, FileConnectionsReader, CompanyDataReader, DeliveryMethodRepo, AdminRepo, PaymentDetailsRepo, AddressesRepo, ClientAccountRepo, CompanyDetailsRepo, ContactDetailsRepo, DeliveryDetailsRepo, CompanyDataRepo, InvoiceDetailsRepo, OrderRepo, PersonalDataRepo, PaymentMethodRepo, ProductRepo, FileConnectionsRepo, FilesRepo, OrderProductsRepo, OrderStatusRepo, Address, Admin, Client, CompanyDetails, ContactDetails, DeliveryDetails, InvoiceDetails, DeliveryStatus, Order, OrderProduct, PaymentDetails, PaymentStatus, PersonalData, Product, Status, };
84
+ import CompanyData from "./stockObjects/CompanyData";
85
+ import CompanyDataRepo from "./repo/CompanyDataRepo";
86
+ import CompanyDataReader from "./reader/CompanyDataReader";
87
+ import CompanyDataI from "./types/CompanyDataI";
88
+ import StatusTypesReader from './reader/StatusTypesReader';
89
+ export { DatabaseConnection, StockObject, StockObjectMapper, Table, Query, TableConnection, ParameterType, ParameterFilter, ConnectorE, ParameterI, QueryOptionsI, ResultLimitationI, Parameters, OrderByI, QueryOptions, Client, ClientAccountRepo, ClientAccountReader, Address, AddressI, AddressesRepo, AddressesReader, PersonalData, PersonalDataRepo, PersonalDataReader, PersonalDataI, CompanyDetails, CompanyDetailsRepo, CompanyDetailsReader, CompanyDetailsI, ContactDetails, ContactDetailsRepo, ContactDetailsReader, ContactDetailsI, DeliveryDetails, DeliveryDetailsRepo, DeliveryDetailsReader, DeliveryDetailsI, DeliveryMethods, DeliveryMethodRepo, DeliveryMethodReader, DeliveryMethodI, DeliveryStatus, DeliveryStatusReader, InvoiceDetails, InvoiceDetailsRepo, InvoiceDetailsReader, InvoiceDetailsI, PaymentDetails, PaymentDetailsRepo, PaymentDetailsReader, PaymentDetailsI, PaymentMethods, PaymentMethodRepo, PaymentMethodReader, PaymentMethodE, PaymentMethodI, PaymentStatus, PaymentStatusesReader, PaymentStatusE, Order, OrderRepo, OrderReader, OrderProduct, OrderProductsRepo, OrderProductsReader, OrderProductI, Status, OrderStatusRepo, OrderStatusReader, StatusI, ProductI, Product, ProductRepo, ProductReader, File, FilesRepo, FilesReader, FileI, FileConnection, FileConnectionsRepo, FileConnectionsReader, FileConnectionTypeE, CompanyData, CompanyDataRepo, CompanyDataReader, CompanyDataI, StatusTypesReader, };
package/dist/index.js CHANGED
@@ -1,64 +1,69 @@
1
1
  import DatabaseConnection from "./DatabaseConnection";
2
2
  import StockObject from "./types/StockObject";
3
- import AddressesReader from "./reader/AddressesReader";
3
+ import Table from "./Table";
4
+ import Query from "./query/Query";
5
+ import TableConnection from './TableConnection';
6
+ import ParameterType from './types/parameters/ParameterType';
7
+ import ConnectorE from './types/ConnectorE';
8
+ import Parameters from './utils/Parameters';
9
+ import QueryOptions from './query/QueryOptions';
10
+ import Client from "./stockObjects/Client";
11
+ import ClientAccountRepo from "./repo/ClientAccountRepo";
4
12
  import ClientAccountReader from "./reader/ClientAccountReader";
13
+ import Address from "./stockObjects/Address";
14
+ import AddressesRepo from "./repo/AddressesRepo";
15
+ import AddressesReader from "./reader/AddressesReader";
16
+ import PersonalData from "./stockObjects/PersonalData";
17
+ import PersonalDataRepo from "./repo/PersonalDataRepo";
18
+ import PersonalDataReader from "./reader/PersonalDataReader";
19
+ import CompanyDetails from "./stockObjects/CompanyDetails";
20
+ import CompanyDetailsRepo from "./repo/CompanyDetailsRepo";
5
21
  import CompanyDetailsReader from "./reader/CompanyDetailsReader";
22
+ import ContactDetails from "./stockObjects/ContactDetails";
23
+ import ContactDetailsRepo from "./repo/ContactDetailsRepo";
6
24
  import ContactDetailsReader from "./reader/ContactDetailsReader";
25
+ import DeliveryDetails from "./stockObjects/DeliveryDetails";
26
+ import DeliveryDetailsRepo from "./repo/DeliveryDetailsRepo";
7
27
  import DeliveryDetailsReader from "./reader/DeliveryDetailsReader";
28
+ import DeliveryMethods from "./stockObjects/DeliveryMethods";
29
+ import DeliveryMethodRepo from './repo/DeliveryMethodRepo';
8
30
  import DeliveryMethodReader from "./reader/DeliveryMethodReader";
31
+ import DeliveryStatus from "./stockObjects/DeliveryStatus";
32
+ import DeliveryStatusReader from './reader/DeliveryStatusReader';
33
+ import InvoiceDetails from "./stockObjects/InvoiceDetails";
34
+ import InvoiceDetailsRepo from "./repo/InvoiceDetailsRepo";
9
35
  import InvoiceDetailsReader from "./reader/InvoiceDetailsReader";
10
- import OrderProductsReader from "./reader/OrderProductsReader";
11
- import OrderReader from "./reader/OrderReader";
12
- import FilesReader from './reader/FilesReader';
13
- import OrderStatusReader from "./reader/OrderStatusReader";
14
- import OrderStatusRepo from "./repo/OrderStatusRepo";
36
+ import PaymentDetails from "./stockObjects/PaymentDetails";
37
+ import PaymentDetailsRepo from "./repo/PaymentDetailsRepo";
15
38
  import PaymentDetailsReader from "./reader/payment/PaymentDetailsReader";
39
+ import PaymentMethods from "./stockObjects/PaymentMethods";
40
+ import PaymentMethodRepo from './repo/PaymentMethodRepo';
16
41
  import PaymentMethodReader from "./reader/payment/PaymentMethodReader";
42
+ import PaymentMethodE from "./types/PaymentMethodE";
43
+ import PaymentStatus from "./stockObjects/PaymentStatus";
17
44
  import PaymentStatusesReader from "./reader/payment/PaymentStatusesReader";
18
- import PersonalDataReader from "./reader/PersonalDataReader";
19
- import ProductReader from "./reader/ProductReader";
20
- import AddressesRepo from "./repo/AddressesRepo";
21
- import ClientAccountRepo from "./repo/ClientAccountRepo";
22
- import CompanyDetailsRepo from "./repo/CompanyDetailsRepo";
23
- import CompanyDataRepo from "./repo/CompanyDataRepo";
24
- import ContactDetailsRepo from "./repo/ContactDetailsRepo";
25
- import DeliveryDetailsRepo from "./repo/DeliveryDetailsRepo";
26
- import InvoiceDetailsRepo from "./repo/InvoiceDetailsRepo";
27
- import OrderRepo from "./repo/OrderRepo";
28
- import PaymentDetailsRepo from "./repo/PaymentDetailsRepo";
29
- import PersonalDataRepo from "./repo/PersonalDataRepo";
30
- import PaymentMethodRepo from './repo/PaymentMethodRepo';
31
- import ProductRepo from "./repo/ProductRepo";
32
- import Address from "./stockObjects/Address";
33
- import Admin from "./stockObjects/Admin";
34
- import CompanyDetails from "./stockObjects/CompanyDetails";
35
- import ContactDetails from "./stockObjects/ContactDetails";
36
- import DeliveryDetails from "./stockObjects/DeliveryDetails";
37
- import DeliveryStatus from "./stockObjects/DeliveryStatus";
38
- import InvoiceDetails from "./stockObjects/InvoiceDetails";
45
+ import PaymentStatusE from './types/PaymentStatusE';
39
46
  import Order from "./stockObjects/Order";
47
+ import OrderRepo from "./repo/OrderRepo";
48
+ import OrderReader from "./reader/OrderReader";
40
49
  import OrderProduct from "./stockObjects/OrderProduct";
41
- import PaymentDetails from "./stockObjects/PaymentDetails";
42
- import PaymentStatus from "./stockObjects/PaymentStatus";
43
- import PersonalData from "./stockObjects/PersonalData";
44
- import Product from "./stockObjects/Product";
50
+ import OrderProductsRepo from "./repo/OrderProductsRepo";
51
+ import OrderProductsReader from "./reader/OrderProductsReader";
45
52
  import Status from "./stockObjects/Status";
46
- import Client from "./stockObjects/Client";
47
- import AdminRepo from './repo/AdminRepo';
48
- import TableConnection from './TableConnection';
49
- import ParameterType from './types/parameters/ParameterType';
50
- import DeliveryStatusReader from './reader/DeliveryStatusReader';
51
- import ConnectorE from './types/ConnectorE';
52
- import PaymentStatusE from './types/PaymentStatusE';
53
- import Parameters from './utils/Parameters';
54
- import DeliveryMethodRepo from './repo/DeliveryMethodRepo';
55
- import StatusTypesReader from './reader/StatusTypesReader';
56
- import FileConnectionsReader from "./reader/FileConnectionsReader";
57
- import FileConnectionsRepo from "./repo/FileConnectionsRepo";
58
- import CompanyDataReader from "./reader/CompanyDataReader";
59
- import FilesRepo from './repo/FilesRepo';
53
+ import OrderStatusRepo from "./repo/OrderStatusRepo";
54
+ import OrderStatusReader from "./reader/OrderStatusReader";
55
+ import Product from "./stockObjects/Product";
56
+ import ProductRepo from "./repo/ProductRepo";
57
+ import ProductReader from "./reader/ProductReader";
60
58
  import File from './stockObjects/File';
61
- import QueryOptions from './query/QueryOptions';
62
- import OrderProductsRepo from "./repo/OrderProductsRepo";
59
+ import FilesRepo from './repo/FilesRepo';
60
+ import FilesReader from './reader/FilesReader';
61
+ import FileConnection from "./stockObjects/FileConnection";
62
+ import FileConnectionsRepo from "./repo/FileConnectionsRepo";
63
+ import FileConnectionsReader from "./reader/FileConnectionsReader";
63
64
  import FileConnectionTypeE from './types/FileConnectionTypeE';
64
- export { TableConnection, StockObject, DatabaseConnection, File, ParameterType, ConnectorE, FileConnectionTypeE, PaymentStatusE, Parameters, QueryOptions, PaymentDetailsReader, FilesReader, PaymentMethodReader, DeliveryStatusReader, PaymentStatusesReader, AddressesReader, ClientAccountReader, CompanyDetailsReader, ContactDetailsReader, DeliveryDetailsReader, DeliveryMethodReader, InvoiceDetailsReader, OrderProductsReader, OrderReader, OrderStatusReader, PersonalDataReader, ProductReader, StatusTypesReader, FileConnectionsReader, CompanyDataReader, DeliveryMethodRepo, AdminRepo, PaymentDetailsRepo, AddressesRepo, ClientAccountRepo, CompanyDetailsRepo, ContactDetailsRepo, DeliveryDetailsRepo, CompanyDataRepo, InvoiceDetailsRepo, OrderRepo, PersonalDataRepo, PaymentMethodRepo, ProductRepo, FileConnectionsRepo, FilesRepo, OrderProductsRepo, OrderStatusRepo, Address, Admin, Client, CompanyDetails, ContactDetails, DeliveryDetails, InvoiceDetails, DeliveryStatus, Order, OrderProduct, PaymentDetails, PaymentStatus, PersonalData, Product, Status, };
65
+ import CompanyData from "./stockObjects/CompanyData";
66
+ import CompanyDataRepo from "./repo/CompanyDataRepo";
67
+ import CompanyDataReader from "./reader/CompanyDataReader";
68
+ import StatusTypesReader from './reader/StatusTypesReader';
69
+ export { DatabaseConnection, StockObject, Table, Query, TableConnection, ParameterType, ConnectorE, Parameters, QueryOptions, Client, ClientAccountRepo, ClientAccountReader, Address, AddressesRepo, AddressesReader, PersonalData, PersonalDataRepo, PersonalDataReader, CompanyDetails, CompanyDetailsRepo, CompanyDetailsReader, ContactDetails, ContactDetailsRepo, ContactDetailsReader, DeliveryDetails, DeliveryDetailsRepo, DeliveryDetailsReader, DeliveryMethods, DeliveryMethodRepo, DeliveryMethodReader, DeliveryStatus, DeliveryStatusReader, InvoiceDetails, InvoiceDetailsRepo, InvoiceDetailsReader, PaymentDetails, PaymentDetailsRepo, PaymentDetailsReader, PaymentMethods, PaymentMethodRepo, PaymentMethodReader, PaymentMethodE, PaymentStatus, PaymentStatusesReader, PaymentStatusE, Order, OrderRepo, OrderReader, OrderProduct, OrderProductsRepo, OrderProductsReader, Status, OrderStatusRepo, OrderStatusReader, Product, ProductRepo, ProductReader, File, FilesRepo, FilesReader, FileConnection, FileConnectionsRepo, FileConnectionsReader, FileConnectionTypeE, CompanyData, CompanyDataRepo, CompanyDataReader, StatusTypesReader, };
@@ -39,6 +39,7 @@ export default class FilesReader {
39
39
  name: file.name,
40
40
  catalog: file.catalog,
41
41
  type: file.type,
42
+ createdAt: file.created_at
42
43
  };
43
44
  return correctFile;
44
45
  }
@@ -6,7 +6,6 @@ export default class ProductReader {
6
6
  static getAllActive(queryOptions: QueryOptionsI): Promise<ProductI[]>;
7
7
  static getIdForSku(productSku: string): Promise<number>;
8
8
  static getQuantity(queryOptions: QueryOptionsI): Promise<number>;
9
- private static correctProductWithGraphics;
10
9
  private static correctProducts;
11
10
  private static correctProduct;
12
11
  }
@@ -6,12 +6,14 @@ export default class ProductReader {
6
6
  static async get(productId) {
7
7
  const connection = DatabaseConnection.get();
8
8
  const product = await connection.products.select(productId);
9
- return await this.correctProductWithGraphics(product);
9
+ const files = await FilesReader.getForConnection(FileConnectionTypeE.product, product.id);
10
+ return this.correctProduct(product, files);
10
11
  }
11
12
  static async getForUrl(productUrl) {
12
13
  const connection = DatabaseConnection.get();
13
14
  const product = await connection.products.selectForUrl(productUrl);
14
- return await this.correctProductWithGraphics(product);
15
+ const files = await FilesReader.getForConnection(FileConnectionTypeE.product, product.id);
16
+ return this.correctProduct(product, files);
15
17
  }
16
18
  static async getAllActive(queryOptions) {
17
19
  const connection = DatabaseConnection.get();
@@ -27,20 +29,16 @@ export default class ProductReader {
27
29
  const quantity = await connection.products.count(queryOptions);
28
30
  return quantity;
29
31
  }
30
- static async correctProductWithGraphics(product) {
31
- const thumbnail = await FilesReader.get(product.file_id);
32
- const files = await FilesReader.getForConnection(FileConnectionTypeE.product, product.id);
33
- return this.correctProduct(product, thumbnail, files);
34
- }
35
- static correctProducts(products) {
32
+ static async correctProducts(products) {
36
33
  const correctProducts = [];
37
34
  for (let i = 0; i < products.length; i++) {
38
- const correctProduct = this.correctProduct(products[i]);
35
+ const correctProduct = await this.correctProduct(products[i]);
39
36
  correctProducts.push(correctProduct);
40
37
  }
41
38
  return correctProducts;
42
39
  }
43
- static correctProduct(product, thumbnail, files) {
40
+ static async correctProduct(product, files) {
41
+ const thumbnail = await FilesReader.get(product.file_id);
44
42
  return {
45
43
  id: product.id,
46
44
  sku: product.sku,
@@ -24,7 +24,7 @@ export default class StatusesTable extends Table {
24
24
  bindParameters(query, status) {
25
25
  query.bindParameter('order_id', status.getOrderId());
26
26
  query.bindParameter('user_id', status.getUserId());
27
- query.bindParameter('type', status.getType());
27
+ query.bindParameter('type', status.getTypeId());
28
28
  }
29
29
  async selectNextId() {
30
30
  const query = this.createQuery(SQL.statuses.selectNextId);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dascompany/database",
3
- "version": "0.0.9",
3
+ "version": "1.0.1",
4
4
  "main": "dist/index.js",
5
5
  "scripts": {
6
6
  "test": "vitest",
@@ -1,9 +0,0 @@
1
- import Admin from "../stockObjects/Admin";
2
- import StockObjectMapper from "../types/StockObjectMapper";
3
- export default class AdminMapper implements StockObjectMapper {
4
- private admin;
5
- private adminAccountsTable;
6
- constructor(admin: Admin);
7
- save(): Promise<void>;
8
- delete(): Promise<void>;
9
- }
@@ -1,24 +0,0 @@
1
- import DatabaseConnection from "../DatabaseConnection";
2
- export default class AdminMapper {
3
- admin;
4
- adminAccountsTable;
5
- constructor(admin) {
6
- this.adminAccountsTable = DatabaseConnection.get().adminAccounts;
7
- this.admin = admin;
8
- }
9
- async save() {
10
- if (!this.admin.getDeleted()) {
11
- if (this.admin.getId())
12
- await this.adminAccountsTable.update(this.admin);
13
- else
14
- await this.adminAccountsTable.insert(this.admin);
15
- }
16
- else
17
- throw new Error(`Admin account ${this.admin.getId()} is deleted. Restore before updating.`);
18
- }
19
- async delete() {
20
- const id = this.admin.getId();
21
- if (id)
22
- await this.adminAccountsTable.delete(id);
23
- }
24
- }
@@ -1,12 +0,0 @@
1
- import Admin from "../stockObjects/Admin";
2
- import QueryOptionsI from "../types/QueryOptionsI";
3
- export default class AdminRepo {
4
- static get(accountId: number): Promise<Admin>;
5
- static getIdForEmail(email: string): Promise<number>;
6
- static getAll(queryOptions: QueryOptionsI): Promise<{
7
- adminAccounts: Admin[];
8
- quantity: number;
9
- }>;
10
- private static createAdminsFromRows;
11
- private static createAdminFromRow;
12
- }
@@ -1,32 +0,0 @@
1
- import DatabaseConnection from "../DatabaseConnection";
2
- import Admin from "../stockObjects/Admin";
3
- export default class AdminRepo {
4
- static async get(accountId) {
5
- const connection = DatabaseConnection.get();
6
- const account = await connection.adminAccounts.select(accountId);
7
- return this.createAdminFromRow(account);
8
- }
9
- static async getIdForEmail(email) {
10
- const connection = DatabaseConnection.get();
11
- return await connection.adminAccounts.selectForEmail(email);
12
- }
13
- static async getAll(queryOptions) {
14
- const connection = DatabaseConnection.get();
15
- const adminAccounts = await connection.adminAccounts.selectAll(queryOptions);
16
- const quantity = await connection.adminAccounts.count(queryOptions);
17
- return { adminAccounts: this.createAdminsFromRows(adminAccounts), quantity };
18
- }
19
- static createAdminsFromRows(dataRows) {
20
- const admins = [];
21
- for (const dataRow of dataRows) {
22
- const admin = this.createAdminFromRow(dataRow);
23
- admins.push(admin);
24
- }
25
- return admins;
26
- }
27
- static createAdminFromRow(dataRow) {
28
- const admin = new Admin(dataRow.email, dataRow.first_name, dataRow.last_name, dataRow.activated, dataRow.deleted, dataRow.created_at);
29
- admin.setId(dataRow.id);
30
- return admin;
31
- }
32
- }
@@ -1,25 +0,0 @@
1
- import ClaimI from "../types/ClaimI";
2
- import StockObject from "../types/StockObject";
3
- import StockObjectMapper from "../types/StockObjectMapper";
4
- export default class Admin extends StockObject {
5
- private email;
6
- private activated;
7
- private deleted;
8
- private firstName;
9
- private lastName;
10
- private createdAt;
11
- private claims;
12
- constructor(email: string, firstName: string, lastName: string, activated: boolean, deleted?: boolean, createdAt?: string | null);
13
- getEmail(): string;
14
- getActivated(): boolean;
15
- getDeleted(): boolean;
16
- getCreatedAt(): string | null;
17
- getFirstName(): string;
18
- getLastName(): string;
19
- setActivated(activated: boolean): void;
20
- setDeleted(deleted: boolean): void;
21
- setFirstName(firstName: string): void;
22
- setLastName(lastName: string): void;
23
- setClaims(claims: ClaimI[]): void;
24
- protected getMapper(): StockObjectMapper;
25
- }
@@ -1,57 +0,0 @@
1
- import AdminMapper from "../mappers/AdminMapper";
2
- import StockObject from "../types/StockObject";
3
- export default class Admin extends StockObject {
4
- email;
5
- activated;
6
- deleted;
7
- firstName;
8
- lastName;
9
- createdAt;
10
- claims;
11
- constructor(email, firstName, lastName, activated, deleted = false, createdAt = null) {
12
- super();
13
- this.email = email;
14
- this.activated = activated;
15
- this.deleted = deleted;
16
- this.firstName = firstName;
17
- this.lastName = lastName;
18
- this.createdAt = createdAt;
19
- this.claims = null;
20
- }
21
- getEmail() {
22
- return this.email;
23
- }
24
- getActivated() {
25
- return this.activated;
26
- }
27
- getDeleted() {
28
- return this.deleted;
29
- }
30
- getCreatedAt() {
31
- return this.createdAt;
32
- }
33
- getFirstName() {
34
- return this.firstName;
35
- }
36
- getLastName() {
37
- return this.lastName;
38
- }
39
- setActivated(activated) {
40
- this.activated = activated;
41
- }
42
- setDeleted(deleted) {
43
- this.deleted = deleted;
44
- }
45
- setFirstName(firstName) {
46
- this.firstName = firstName;
47
- }
48
- setLastName(lastName) {
49
- this.lastName = lastName;
50
- }
51
- setClaims(claims) {
52
- this.claims = claims;
53
- }
54
- getMapper() {
55
- return new AdminMapper(this);
56
- }
57
- }
@@ -1,15 +0,0 @@
1
- import QueryOptionsI from "../../types/QueryOptionsI";
2
- import Table from "../../Table";
3
- import AdminRow from "../../types/rows/AdminRow";
4
- import Admin from "../../stockObjects/Admin";
5
- export default class AdminAccountsTable extends Table {
6
- select(accountId: number): Promise<AdminRow>;
7
- selectAll(queryOptions: QueryOptionsI): Promise<AdminRow[]>;
8
- selectForEmail(email: string): Promise<number>;
9
- count(queryOptions: QueryOptionsI): Promise<number>;
10
- insert(admin: Admin): Promise<number>;
11
- update(admin: Admin): Promise<boolean>;
12
- delete(accountId: number): Promise<number>;
13
- private bindParameters;
14
- private selectNextId;
15
- }
@@ -1,64 +0,0 @@
1
- import Table from "../../Table";
2
- import * as SQL from '../../SQL.json';
3
- export default class AdminAccountsTable extends Table {
4
- async select(accountId) {
5
- const query = this.createQuery(SQL.adminAccounts.select);
6
- query.bindParameter('id', accountId);
7
- const result = await query.execute();
8
- return result.getRow();
9
- }
10
- async selectAll(queryOptions) {
11
- const query = this.createQuery(SQL.adminAccounts.selectAll, queryOptions);
12
- const result = await query.execute();
13
- return result.getRows();
14
- }
15
- async selectForEmail(email) {
16
- const query = this.createQuery(SQL.adminAccounts.selectForEmail);
17
- query.bindParameter('email', String(email).toUpperCase());
18
- const result = await query.execute();
19
- return result.getValue();
20
- }
21
- async count(queryOptions) {
22
- const query = this.createQuery(SQL.adminAccounts.count, queryOptions);
23
- const result = await query.execute();
24
- return result.getValue();
25
- }
26
- async insert(admin) {
27
- let accountId = await this.selectForEmail(admin.getEmail());
28
- if (accountId)
29
- throw new Error(`Admin account with email: ${admin.getEmail()} already exist!`);
30
- else
31
- accountId = await this.selectNextId();
32
- const query = this.createQuery(SQL.adminAccounts.insert);
33
- query.bindParameter('id', accountId);
34
- this.bindParameters(query, admin);
35
- await query.execute();
36
- admin.setId(accountId);
37
- return accountId;
38
- }
39
- async update(admin) {
40
- const query = this.createQuery(SQL.adminAccounts.update);
41
- query.bindParameter('id', admin.getId());
42
- this.bindParameters(query, admin);
43
- await query.execute();
44
- return true;
45
- }
46
- async delete(accountId) {
47
- const query = this.createQuery(SQL.adminAccounts.delete);
48
- query.bindParameter('id', accountId);
49
- const result = await query.execute();
50
- return result.getRowCount();
51
- }
52
- bindParameters(query, admin) {
53
- query.bindParameter('email', admin.getEmail());
54
- query.bindParameter('first_name', admin.getFirstName());
55
- query.bindParameter('last_name', admin.getLastName());
56
- query.bindParameter('activated', admin.getActivated());
57
- query.bindParameter('deleted', admin.getDeleted());
58
- }
59
- async selectNextId() {
60
- const query = this.createQuery(SQL.adminAccounts.selectNextId);
61
- const result = await query.execute();
62
- return result.getValue();
63
- }
64
- }
@@ -1,9 +0,0 @@
1
- export default interface AdminRow {
2
- id: number;
3
- email: string;
4
- first_name: string;
5
- last_name: string;
6
- activated: boolean;
7
- deleted: boolean;
8
- created_at: string;
9
- }
@@ -1 +0,0 @@
1
- export {};