Service - Delivery Method Rate Table: Difference between revisions

From Izara Wiki
Jump to navigation Jump to search
 
(3 intermediate revisions by the same user not shown)
Line 20: Line 20:
}
}
</syntaxhighlight>
</syntaxhighlight>
== LogicalResultsMain ==
[[Standard LogicalResults Per Service|LogicalResultsMain]]
== LogicalResultsData ==
[[Standard LogicalResults Per Service|LogicalResultsData]]
== LogicalAwaitingStep ==
[[Standard LogicalResults Per Service|LogicalAwaitingStep]]


= Graph database =  
= Graph database =  
Line 42: Line 51:
}
}
</syntaxhighlight>
</syntaxhighlight>
* see [[NPM module - Izara Core - Property Node|DataSchemaLib]]


=== Versioned data ===
=== Versioned data ===
Line 74: Line 81:
<syntaxhighlight lang="JavaScript">
<syntaxhighlight lang="JavaScript">
{
{
relationshipType: "{DeliveryMethodRateTableLib.createDeliversToLocationNodeRelationshipType()}", // "deliversTo_locationNode"
relationshipType: "{DeliveryMethodStandardLib.createHasDeliveryMethodRateTableGraphRelationshipType()}", // "deliversTo_locationNode"
schema: {
elementCanBeRemoved: true,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
</syntaxhighlight>
<syntaxhighlight lang="JavaScript">
{
relationshipType: "{DeliveryMethodStandardLib.createDisabledDeliveryMethodRateTableGraphRelationshipType()}", // "disabledDeliversTo_locationNode"
schema: {
schema: {
elementCanBeRemoved: false,
elementCanBeRemoved: true,
allPropertiesImmutable: true,
allPropertiesImmutable: true,
restrictProperties: true,
restrictProperties: true,
properties: {
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
originTimestamp: //timestamp the request to create/change this relationship was sent
addedByuserId: //userId that added this relationship
},
},
}
}
}
}
</syntaxhighlight>
</syntaxhighlight>
* no versionedData or disabled link, just create a relationship from rateTable to user each time locationNode removed
 
* enable/disable links to locationNodes
* after a locationNode relationship is added to a RateTable it always remains as either one of the above relationships, in order to maintain history of changes


<syntaxhighlight lang="JavaScript">
<syntaxhighlight lang="JavaScript">
{
{
relationshipType: "{DeliveryMethodRateTableLib.createRemovedDeliversToLocationNodeRelationshipType()}", // "removed_deliversToLocationNode"
relationshipType: "adjustDeliversTo_performedBy"
schema: {
schema: {
elementCanBeRemoved: false,
elementCanBeRemoved: false,
Line 97: Line 118:
properties: {
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
originTimestamp: //timestamp the request to create/change this relationship was sent
locationNodeId: // the locationNode removed
locationNodeId:
action: // "added"|"enabled"|"disabled"
},
},
}
}
}
}
</syntaxhighlight>
</syntaxhighlight>
* creates a relationship between user and rateTable each time a user removes a deliversTo locationNode
 
* adds a relationship record between rateTable node and user whenever delivers to relationship added or removed


= Data structure notes =
= Data structure notes =

Latest revision as of 12:12, 1 February 2023

Overview

Manages delivery rate tables for delivery methods (possible other objects). Rate tables combine set rates at a certain value with increment settings to easily maintain rate table calculations.

Repository

https://bitbucket.org/izara-market-products/izara-market-products-delivery-method-rate-table

DynamoDB tables

Standard Config Table Per Service

Configuration tags

{
	configTag: "ProductGraphServiceName"
	configKey: "ProductGraphServiceName"
	configValue: xxx // eg: "ProductGraph"
}

LogicalResultsMain

LogicalResultsMain

LogicalResultsData

LogicalResultsData

LogicalAwaitingStep

LogicalAwaitingStep

Graph database

Service - Products Graph

Nodes

{
	nodeLabel: "{DeliveryMethodRateTableLib.RATETABLE_GRAPH_NODE_LABEL}", // "rateTable"
	schema: {
		identifier: true,
		restrictProperties: true,
		restrictRelationships: true,
		properties: {
			rateTableId: {
				identifier: true, // create unique id from request params and uniqueMessageId
			},
		},
	}
}

Versioned data

rateTableRates

{
	properties: {
		rates: [
			{
				type: "setRate",
				upToValue: xx, // numeric value that this setRate goes up to
				rate: xx, // numeric rate
			},
			{
				type: "increment",
				upToValue: xx, // numeric value that this setRate goes up to
				ratePerIncrement: xx, // numeric amount that rate increases per increment
				increment: xx, // numeric incremental amount
			},
			// ..
		],
	},
}

Relationships

{
	relationshipType: "{DeliveryMethodStandardLib.createHasDeliveryMethodRateTableGraphRelationshipType()}", // "deliversTo_locationNode"
	schema: {
		elementCanBeRemoved: true,
		allPropertiesImmutable: true,
		restrictProperties: true,
		properties: {
			originTimestamp: //timestamp the request to create/change this relationship was sent
		},
	}
}
{
	relationshipType: "{DeliveryMethodStandardLib.createDisabledDeliveryMethodRateTableGraphRelationshipType()}", // "disabledDeliversTo_locationNode"
	schema: {
		elementCanBeRemoved: true,
		allPropertiesImmutable: true,
		restrictProperties: true,
		properties: {
			originTimestamp: //timestamp the request to create/change this relationship was sent
		},
	}
}
  • enable/disable links to locationNodes
  • after a locationNode relationship is added to a RateTable it always remains as either one of the above relationships, in order to maintain history of changes
{
	relationshipType: "adjustDeliversTo_performedBy"
	schema: {
		elementCanBeRemoved: false,
		allPropertiesImmutable: true,
		restrictProperties: true,
		properties: {
			originTimestamp: //timestamp the request to create/change this relationship was sent
			locationNodeId: 
			action: // "added"|"enabled"|"disabled"
		},
	}
}
  • adds a relationship record between rateTable node and user whenever delivers to relationship added or removed

Data structure notes

  • multiple deliveryMethods could point to a single rateTable

Complex Filter requests

{
	filterType: "deliveryMethodRateTable" //unique id is rateTableId
	type: "group",
	elements:
	[
		{
			type: "logical",
			logicalTag: "deliverToLocationId",
			comparison: "equals",
			value: "xx"
		},
		{
			// finds all rateTables that has at >=1 has_deliveryMethodRateTable incomming relationship from give sellOfferPlanDeliveryMethodLinkId
			type: "logical",
			logicalTag: "activeSellOfferPlanDeliveryMethodLinkId",
			comparison: "equals",
			value: "xx"
		},	
		{
			// finds all rateTables that has at >=1 has_deliveryMethodRateTable incomming relationship
			type: "logical",
			logicalTag: "isEnabled",
			comparison: "true",
		},		
		...
	]
}

Working documents

Delivery Method Rate Table