Work in progress on integration of IVIS.
Some fixes.
This commit is contained in:
		
							parent
							
								
									3a17d7fd75
								
							
						
					
					
						commit
						2aaa8f45b3
					
				
					 11 changed files with 188 additions and 12 deletions
				
			
		|  | @ -1,12 +1,11 @@ | |||
| const webpack = require('webpack'); | ||||
| const path = require('path'); | ||||
| 
 | ||||
| const webpackConf = require('../ivis-core/client/webpack.config'); | ||||
| 
 | ||||
| webpackConf.resolve.modules = ['node_modules', '../ivis-core/client/node_modules']; | ||||
| webpackConf.entry = { | ||||
|     'index-trusted': ['babel-polyfill', './src/root-trusted.js'], | ||||
|     'index-sandbox': ['babel-polyfill', '../ivis-core/client/src/root-sandbox.js'] | ||||
|     'index-trusted': ['@babel/polyfill', './src/root-trusted.js'], | ||||
|     'index-sandbox': ['@babel/polyfill', '../ivis-core/client/src/root-sandbox.js'] | ||||
| }; | ||||
| webpackConf.output = { | ||||
|     filename: '[name].js', | ||||
|  |  | |||
|  | @ -1 +1 @@ | |||
| Subproject commit 052fbff6e4eaba52eee2f984f2b8d947ebfa7298 | ||||
| Subproject commit 5ea4783f3ec5140ad68637c31e230a410e493170 | ||||
|  | @ -6,8 +6,7 @@ mysql: | |||
| 
 | ||||
| mailtrain: | ||||
|   url: http://localhost:3000/ | ||||
|   namespaces: | ||||
|     campaigns: 2 | ||||
|   namespace: 1 | ||||
|   userRole: mailtrainUser | ||||
| 
 | ||||
| www: | ||||
|  |  | |||
|  | @ -5,6 +5,7 @@ const path = require('path'); | |||
| 
 | ||||
| em.set('config.extraDirs', [ path.join(__dirname, 'config') ]); | ||||
| em.set('builder.exec', path.join(__dirname, 'builder.js')); | ||||
| em.set('task-handler.exec', path.join(__dirname, 'task-handler.js')); | ||||
| em.set('indexer.elasticsearch.exec', path.join(__dirname, 'indexer-elasticsearch.js')); | ||||
| em.set('app.title', 'Mailtrain IVIS'); | ||||
| 
 | ||||
|  |  | |||
|  | @ -15,6 +15,9 @@ em.on('knex.migrate', async () => { | |||
| em.on('app.installAPIRoutes', app => { | ||||
|     const embedApi = require('./routes/api/embed'); | ||||
|     app.use('/api', embedApi); | ||||
| 
 | ||||
|     const eventsApi = require('./routes/api/events'); | ||||
|     app.use('/api', eventsApi); | ||||
| }); | ||||
| 
 | ||||
| require('../ivis-core/server/index'); | ||||
|  |  | |||
							
								
								
									
										123
									
								
								mvis/server/routes/api/events.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										123
									
								
								mvis/server/routes/api/events.js
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,123 @@ | |||
| 'use strict'; | ||||
| 
 | ||||
| const config = require('../../../ivis-core/server/lib/config'); | ||||
| const moment = require('moment'); | ||||
| const knex = require('../../../ivis-core/server/lib/knex'); | ||||
| const router = require('../../../ivis-core/server/lib/router-async').create(); | ||||
| const log = require('../../../ivis-core/server/lib/log'); | ||||
| const signalSets = require('../../../ivis-core/server/models/signal-sets'); | ||||
| const { SignalType } = require('../../../ivis-core/shared/signals'); | ||||
| const contextHelpers = require('../../../ivis-core/server/lib/context-helpers'); | ||||
| const namespaces = require('../../../ivis-core/server/models/namespaces'); | ||||
| 
 | ||||
| /* | ||||
| async function ensureCampaignTracker() { | ||||
|     const schema = { | ||||
|         type: { | ||||
|             type: SignalType.INTEGER, | ||||
|             name: 'Type', | ||||
|             settings: {}, | ||||
|             indexed: true, | ||||
|             weight_list: 0, | ||||
|             weight_edit: 0 | ||||
|         }, | ||||
|         timestamp: { | ||||
|             type: SignalType.DATE_TIME, | ||||
|             name: 'Timestamp', | ||||
|             settings: {}, | ||||
|             indexed: true, | ||||
|             weight_list: 1, | ||||
|             weight_edit: 1 | ||||
|         }, | ||||
|         campaignId: { | ||||
|             type: SignalType.INTEGER, | ||||
|             name: 'Campaign ID', | ||||
|             settings: {}, | ||||
|             indexed: true, | ||||
|             weight_list: 2, | ||||
|             weight_edit: 2 | ||||
|         }, | ||||
|         listId: { | ||||
|             type: SignalType.INTEGER, | ||||
|             name: 'List ID', | ||||
|             settings: {}, | ||||
|             indexed: true, | ||||
|             weight_list: 3, | ||||
|             weight_edit: 3 | ||||
|         }, | ||||
|         subscriptionId: { | ||||
|             type: SignalType.INTEGER, | ||||
|             name: 'Subscription ID', | ||||
|             settings: {}, | ||||
|             indexed: true, | ||||
|             weight_list: 4, | ||||
|             weight_edit: 4 | ||||
|         }, | ||||
| 
 | ||||
|     }; | ||||
| 
 | ||||
|     return await signalSets.ensure( | ||||
|         req.context, | ||||
|         'campaignTracker', | ||||
|         schema, | ||||
|         'Campaign Tracker', | ||||
|         '', | ||||
|         config.mailtrain.namespace | ||||
|     ); | ||||
| } | ||||
| 
 | ||||
| async function ingestCampaignTrackerRecord(record) { | ||||
|     return { | ||||
|         id: TODO | ||||
|     }; | ||||
| } | ||||
| 
 | ||||
| const types = { | ||||
|     campaign_tracker: { | ||||
|         ensure: ensureCampaignTracker, | ||||
|         ingest: ingestCampaignTrackerRecord | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| router.postAsync('/events', async (req, res) => { | ||||
|     const batch = req.body; | ||||
| 
 | ||||
|     const recordsByType = {}; | ||||
|     const signalSetWithSignalMapByType = {}; | ||||
| 
 | ||||
|     for (const type in types) { | ||||
|         recordsByType[type] = []; | ||||
|         signalSetWithSignalMapByType[type] = await types[type].ensure(); | ||||
|     } | ||||
| 
 | ||||
|     for (const dataEntry of batch.data) { | ||||
|         const record = { | ||||
|             id: dataEntry[idField], | ||||
|             signals: {} | ||||
|         }; | ||||
| 
 | ||||
|         for (const fieldId in dataEntry) { | ||||
|             if (fieldId !== idField) { | ||||
|                 if (!(fieldId in schema)) { | ||||
|                     throw new Error(`Unknown data field "${fieldId}`); | ||||
|                 } | ||||
| 
 | ||||
|                 let value = dataEntry[fieldId]; | ||||
|                 if (schema[fieldId].type === SignalType.DATE_TIME) { | ||||
|                     value = moment(value); | ||||
|                 } | ||||
| 
 | ||||
|                 record.signals[fieldId] = value; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         records.push(record); | ||||
|     } | ||||
| 
 | ||||
|     await signalSets.insertRecords(req.context, signalSetWithSignalMap, records); | ||||
| 
 | ||||
|     return res.json(); | ||||
| }); | ||||
| */ | ||||
| 
 | ||||
| module.exports = router; | ||||
							
								
								
									
										5
									
								
								mvis/server/task-handler.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								mvis/server/task-handler.js
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| 'use strict'; | ||||
| 
 | ||||
| require('./extensions-common'); | ||||
| require('../ivis-core/server/services/task-handler'); | ||||
| 
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue