-
Notifications
You must be signed in to change notification settings - Fork 352
/
content-service_application.conf
648 lines (575 loc) · 24.5 KB
/
content-service_application.conf
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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
# This is the main configuration file for the application.
# https://www.playframework.com/documentation/latest/ConfigFile
# ~~~~~
# Play uses HOCON as its configuration file format. HOCON has a number
# of advantages over other config formats, but there are two things that
# can be used when modifying settings.
#
# You can include other configuration files in this main application.conf file:
#include "extra-config.conf"
#
# You can declare variables and substitute for them:
#mykey = ${some.value}
#
# And if an environment variable exists when there is no other substitution, then
# HOCON will fall back to substituting environment variable:
#mykey = ${JAVA_HOME}
## Akka
# https://www.playframework.com/documentation/latest/ScalaAkka#Configuration
# https://www.playframework.com/documentation/latest/JavaAkka#Configuration
# ~~~~~
# Play uses Akka internally and exposes Akka Streams and actors in Websockets and
# other streaming HTTP responses.
akka {
# "akka.log-config-on-start" is extraordinarly useful because it log the complete
# configuration at INFO level, including defaults and overrides, so it s worth
# putting at the very top.
#
# Put the following in your conf/logback.xml file:
#
# <logger name="akka.actor" level="INFO" />
#
# And then uncomment this line to debug the configuration.
#
#log-config-on-start = true
default-dispatcher {
# This will be used if you have set "executor = "fork-join-executor""
fork-join-executor {
# Min number of threads to cap factor-based parallelism number to
parallelism-min = 8
# The parallelism factor is used to determine thread pool size using the
# following formula: ceil(available processors * factor). Resulting size
# is then bounded by the parallelism-min and parallelism-max values.
parallelism-factor = 32.0
# Max number of threads to cap factor-based parallelism number to
parallelism-max = 64
# Setting to "FIFO" to use queue like peeking mode which "poll" or "LIFO" to use stack
# like peeking mode which "pop".
task-peeking-mode = "FIFO"
}
}
actors-dispatcher {
type = "Dispatcher"
executor = "fork-join-executor"
fork-join-executor {
parallelism-min = 8
parallelism-factor = 32.0
parallelism-max = 64
}
# Throughput for default Dispatcher, set to 1 for as fair as possible
throughput = 1
}
actor {
deployment {
/contentActor
{
router = smallest-mailbox-pool
nr-of-instances = 10
dispatcher = actors-dispatcher
}
/channelActor
{
router = smallest-mailbox-pool
nr-of-instances = 10
dispatcher = actors-dispatcher
}
/collectionActor
{
router = smallest-mailbox-pool
nr-of-instances = 10
dispatcher = actors-dispatcher
}
/healthActor
{
router = smallest-mailbox-pool
nr-of-instances = 5
dispatcher = actors-dispatcher
}
/licenseActor
{
router = smallest-mailbox-pool
nr-of-instances = 2
dispatcher = actors-dispatcher
}
}
}
}
## Secret key
# http://www.playframework.com/documentation/latest/ApplicationSecret
# ~~~~~
# The secret key is used to sign Play's session cookie.
# This must be changed for production, but we don't recommend you change it in this file.
play.http.secret.key="{{ graph_passport_key }}"
## Modules
# https://www.playframework.com/documentation/latest/Modules
# ~~~~~
# Control which modules are loaded when Play starts. Note that modules are
# the replacement for "GlobalSettings", which are deprecated in 2.5.x.
# Please see https://www.playframework.com/documentation/latest/GlobalSettings
# for more information.
#
# You can also extend Play functionality by using one of the publically available
# Play modules: https://playframework.com/documentation/latest/ModuleDirectory
play.modules {
# By default, Play will load any class called Module that is defined
# in the root package (the "app" directory), or you can define them
# explicitly below.
# If there are any built-in modules that you want to enable, you can list them here.
enabled += modules.ContentModule
# If there are any built-in modules that you want to disable, you can list them here.
#disabled += ""
}
## IDE
# https://www.playframework.com/documentation/latest/IDE
# ~~~~~
# Depending on your IDE, you can add a hyperlink for errors that will jump you
# directly to the code location in the IDE in dev mode. The following line makes
# use of the IntelliJ IDEA REST interface:
#play.editor="http://localhost:63342/api/file/?file=%s&line=%s"
## Internationalisation
# https://www.playframework.com/documentation/latest/JavaI18N
# https://www.playframework.com/documentation/latest/ScalaI18N
# ~~~~~
# Play comes with its own i18n settings, which allow the user's preferred language
# to map through to internal messages, or allow the language to be stored in a cookie.
play.i18n {
# The application languages
langs = [ "en" ]
# Whether the language cookie should be secure or not
#langCookieSecure = true
# Whether the HTTP only attribute of the cookie should be set to true
#langCookieHttpOnly = true
}
## Play HTTP settings
# ~~~~~
play.http {
## Router
# https://www.playframework.com/documentation/latest/JavaRouting
# https://www.playframework.com/documentation/latest/ScalaRouting
# ~~~~~
# Define the Router object to use for this application.
# This router will be looked up first when the application is starting up,
# so make sure this is the entry point.
# Furthermore, it's assumed your route file is named properly.
# So for an application router like `my.application.Router`,
# you may need to define a router file `conf/my.application.routes`.
# Default to Routes in the root package (aka "apps" folder) (and conf/routes)
#router = my.application.Router
## Action Creator
# https://www.playframework.com/documentation/latest/JavaActionCreator
# ~~~~~
#actionCreator = null
## ErrorHandler
# https://www.playframework.com/documentation/latest/JavaRouting
# https://www.playframework.com/documentation/latest/ScalaRouting
# ~~~~~
# If null, will attempt to load a class called ErrorHandler in the root package,
#errorHandler = null
## Session & Flash
# https://www.playframework.com/documentation/latest/JavaSessionFlash
# https://www.playframework.com/documentation/latest/ScalaSessionFlash
# ~~~~~
session {
# Sets the cookie to be sent only over HTTPS.
#secure = true
# Sets the cookie to be accessed only by the server.
#httpOnly = true
# Sets the max-age field of the cookie to 5 minutes.
# NOTE: this only sets when the browser will discard the cookie. Play will consider any
# cookie value with a valid signature to be a valid session forever. To implement a server side session timeout,
# you need to put a timestamp in the session and check it at regular intervals to possibly expire it.
#maxAge = 300
# Sets the domain on the session cookie.
#domain = "example.com"
}
flash {
# Sets the cookie to be sent only over HTTPS.
#secure = true
# Sets the cookie to be accessed only by the server.
#httpOnly = true
}
}
play.server.http.idleTimeout = 60s
play.http.parser.maxDiskBuffer = 100MB
parsers.anyContent.maxLength = 100MB
## Netty Provider
# https://www.playframework.com/documentation/latest/SettingsNetty
# ~~~~~
play.server.netty {
# Whether the Netty wire should be logged
log.wire = true
# If you run Play on Linux, you can use Netty's native socket transport
# for higher performance with less garbage.
transport = "native"
}
## WS (HTTP Client)
# https://www.playframework.com/documentation/latest/ScalaWS#Configuring-WS
# ~~~~~
# The HTTP client primarily used for REST APIs. The default client can be
# configured directly, but you can also create different client instances
# with customized settings. You must enable this by adding to build.sbt:
#
# libraryDependencies += ws // or javaWs if using java
#
play.ws {
# Sets HTTP requests not to follow 302 requests
#followRedirects = false
# Sets the maximum number of open HTTP connections for the client.
#ahc.maxConnectionsTotal = 50
## WS SSL
# https://www.playframework.com/documentation/latest/WsSSL
# ~~~~~
ssl {
# Configuring HTTPS with Play WS does not require programming. You can
# set up both trustManager and keyManager for mutual authentication, and
# turn on JSSE debugging in development with a reload.
#debug.handshake = true
#trustManager = {
# stores = [
# { type = "JKS", path = "exampletrust.jks" }
# ]
#}
}
}
## Cache
# https://www.playframework.com/documentation/latest/JavaCache
# https://www.playframework.com/documentation/latest/ScalaCache
# ~~~~~
# Play comes with an integrated cache API that can reduce the operational
# overhead of repeated requests. You must enable this by adding to build.sbt:
#
# libraryDependencies += cache
#
play.cache {
# If you want to bind several caches, you can bind the individually
#bindCaches = ["db-cache", "user-cache", "session-cache"]
}
## Filter Configuration
# https://www.playframework.com/documentation/latest/Filters
# ~~~~~
# There are a number of built-in filters that can be enabled and configured
# to give Play greater security.
#
play.filters {
# Enabled filters are run automatically against Play.
# CSRFFilter, AllowedHostFilters, and SecurityHeadersFilters are enabled by default.
enabled = [filters.AccessLogFilter]
# Disabled filters remove elements from the enabled list.
# disabled += filters.CSRFFilter
## CORS filter configuration
# https://www.playframework.com/documentation/latest/CorsFilter
# ~~~~~
# CORS is a protocol that allows web applications to make requests from the browser
# across different domains.
# NOTE: You MUST apply the CORS configuration before the CSRF filter, as CSRF has
# dependencies on CORS settings.
cors {
# Filter paths by a whitelist of path prefixes
#pathPrefixes = ["/some/path", ...]
# The allowed origins. If null, all origins are allowed.
#allowedOrigins = ["http://www.example.com"]
# The allowed HTTP methods. If null, all methods are allowed
#allowedHttpMethods = ["GET", "POST"]
}
## Security headers filter configuration
# https://www.playframework.com/documentation/latest/SecurityHeaders
# ~~~~~
# Defines security headers that prevent XSS attacks.
# If enabled, then all options are set to the below configuration by default:
headers {
# The X-Frame-Options header. If null, the header is not set.
#frameOptions = "DENY"
# The X-XSS-Protection header. If null, the header is not set.
#xssProtection = "1; mode=block"
# The X-Content-Type-Options header. If null, the header is not set.
#contentTypeOptions = "nosniff"
# The X-Permitted-Cross-Domain-Policies header. If null, the header is not set.
#permittedCrossDomainPolicies = "master-only"
# The Content-Security-Policy header. If null, the header is not set.
#contentSecurityPolicy = "default-src 'self'"
}
## Allowed hosts filter configuration
# https://www.playframework.com/documentation/latest/AllowedHostsFilter
# ~~~~~
# Play provides a filter that lets you configure which hosts can access your application.
# This is useful to prevent cache poisoning attacks.
hosts {
# Allow requests to example.com, its subdomains, and localhost:9000.
#allowed = [".example.com", "localhost:9000"]
}
}
play.http.parser.maxMemoryBuffer = 50MB
akka.http.parsing.max-content-length = 50MB
schema.base_path="{{kp_schema_base_path | default('/home/sunbird/content-service-1.0-SNAPSHOT/schemas')}}"
# Cassandra Configuration
cassandra {
lp {
connection: "{{ lp_cassandra_connection }}"
}
lpa {
connection: "{{ dp_cassandra_connection }}"
}
}
# Consistency Level for Multi Node Cassandra cluster
{% if (cassandra_cluster_size | int) > 1 %}
cassandra.lp.consistency.level=QUORUM
{% else %}
sunbird_cassandra_consistency_level={{sunbird_cassandra_consistency_level}}
{% endif %}
collection {
keyspace: "{{ lp_cassandra_keyspace_prefix }}_hierarchy_store"
cache.enable: true
image.migration.enabled: true
}
content {
keyspace: "{{ lp_cassandra_keyspace_prefix }}_content_store"
cache {
ttl: 86400
enable: true
}
hierarchy {
removed_props_for_leafNodes: ["collections", "children", "usedByContent", "item_sets", "methods", "libraries", "editorState"]
}
# Added for supporting backward compatibility - remove in release-2.7.0
tagging {
backward_enable: true
property: "subject,medium"
}
h5p {
library {
path: "{{ h5p_library_path | default('https://sunbirddev.blob.core.windows.net/sunbird-content-dev/h5p-standalone-1.3.4.zip') }}"
}
}
copy {
invalid_statusList: ["Flagged","FlaggedDraft","FraggedReview","Retired", "Processing"]
origin_data: ["name", "author", "license", "organisation"]
props_to_remove: ["downloadUrl", "artifactUrl", "variants", "createdOn", "collections", "children", "lastUpdatedOn", "SYS_INTERNAL_LAST_UPDATED_ON", "versionKey", "s3Key", "status", "pkgVersion", "toc_url", "mimeTypesCount", "contentTypesCount", "leafNodesCount", "childNodes", "prevState", "lastPublishedOn", "flagReasons", "compatibilityLevel", "size", "publishChecklist", "publishComment", "LastPublishedBy", "rejectReasons", "rejectComment", "gradeLevel", "subject", "medium", "board", "topic", "purpose", "subtopic", "contentCredits", "owner", "collaborators", "creators", "contributors", "badgeAssertions", "dialcodes", "concepts", "keywords", "reservedDialcodes", "dialcodeRequired", "leafNodes", "sYS_INTERNAL_LAST_UPDATED_ON", "prevStatus", "lastPublishedBy", "streamingUrl", "boardIds", "gradeLevelIds", "subjectIds", "mediumIds", "topicsIds", "targetFWIds", "targetBoardIds", "targetGradeLevelIds", "targetSubjectIds", "targetMediumIds", "targetTopicIds", "se_boards", "se_subjects", "se_mediums", "se_gradeLevels", "se_topics", "se_FWIds", "se_boardIds", "se_subjectIds", "se_mediumIds", "se_gradeLevelIds", "se_topicIds"]
}
media {
base.url: "{{content_media_base_url | default(proto + '://' + domain_name)}}"
}
}
# Redis Configuration
redis {
host: "{{ sunbird_lp_redis_host }}"
port: 6379
maxConnections: 128
}
#--Maximum Content Package File Size Limit in Bytes (50 MB)
MAX_CONTENT_PACKAGE_FILE_SIZE_LIMIT=157286400
#--Maximum Asset File Size Limit in Bytes (50 MB)
MAX_ASSET_FILE_SIZE_LIMIT=157286400
#--No of Retry While File Download Fails
RETRY_ASSET_DOWNLOAD_COUNT=1
#Current environment - need this property post cloud-store implementation
cloud_storage {
env: {{ env }}
content.folder: "content"
asset.folder: "assets"
artefact.folder: "artifact"
bundle.folder: "bundle"
media.folder: "media"
ecar.folder: "ecar_files"
upload.url.ttl: "54000"
}
# Configuration
akka.request_timeout: 30
environment.id: {{ environment_id }}
graph {
dir: "/data/graphDB"
ids: ["domain"]
passport.key.base: "{{ graph_passport_key }}"
}
route {
domain: "{{ learning_neo4j_bolt_url }}"
all: "{{ language_neo4j_bolt_url }}"
bolt {
write {
domain: "{{ learning_write_elb_url }}"
all: "{{ language_write_elb_url }}"
},
read {
domain: "{{ learning_read_elb_url }}"
all: "{{ language_read_elb_url }}"
}
}
}
shard.id: {{ mw_shard_id }}
platform {
auth.check.enabled: false
cache.ttl: 3600000
language.codes: ["as","bn","en","gu","hi","hoc","jun","ka","mai","mr","unx","or","san","sat","ta","te","urd", "pj"]
}
#Top N Config for Search Telemetry
telemetry_env: {{ env }}
installation.id: ekstep
channel {
default: "in.ekstep"
fetch.suggested_frameworks: true
}
languageCode {
assamese : "as"
bengali : "bn"
english : "en"
gujarati : "gu"
hindi : "hi"
kannada : "ka"
marathi : "mr"
odia : "or"
tamil : "ta"
telugu : "te"
}
composite {
search {
url : "{{ sunbird_search_service_api_base_url }}/v3/search"
}
}
cloud_storage_type: "{{ cloud_service_provider }}"
cloud_storage_key: "{{ cloud_public_storage_accountname }}"
cloud_storage_secret: "{{ cloud_public_storage_secret }}"
cloud_storage_endpoint: "{{ cloud_public_storage_endpoint }}"
cloud_storage_container: "{{ cloud_storage_content_bucketname }}"
# Google Drive APIKEY
learning_content_drive_apiKey = "{{ learning_content_drive_apiKey }}"
kafka {
urls : "{{ kafka_urls }}"
topic.send.enable : true
topics.instruction : "{{ env_name }}.learning.job.request"
publish.request.topic : "{{ env_name }}.publish.job.request"
}
# DIAL Link Config
dial_service {
api {
base_url : "http://dial-service.{{namespace}}.svc.cluster.local:9000"
auth_key : "{{ sunbird_dial_repo_api_key }}"
search : "/dialcode/v3/search"
generate : "/dialcode/v3/generate"
}
}
reserve_dialcode {
mimeType : ["application/vnd.ekstep.content-collection"]
max_count : 250
}
content.link_dialcode.validation=true
content.link_dialcode.max_limit=10
# Content Import API Config
import {
request_size_limit : 1000
output_topic_name : "{{ env_name }}.auto.creation.job.request"
required_props : {{ content_import_required_props }}
remove_props : {{ content_import_remove_props }}
}
contentTypeToPrimaryCategory {
ClassroomTeachingVideo: "Explanation Content"
ConceptMap: "Learning Resource"
Course: "Course"
CuriosityQuestionSet: "Practice Question Set"
eTextBook: "eTextbook"
ExperientialResource: "Learning Resource"
ExplanationResource: "Explanation Content"
ExplanationVideo: "Explanation Content"
FocusSpot: "Teacher Resource"
LearningOutcomeDefinition: "Teacher Resource"
MarkingSchemeRubric: "Teacher Resource"
PedagogyFlow: "Teacher Resource"
PracticeQuestionSet: "Practice Question Set"
PracticeResource: "Practice Question Set"
SelfAssess: "Course Assessment"
TeachingMethod: "Teacher Resource"
TextBook: "Digital Textbook"
Collection: "Content Playlist"
ExplanationReadingMaterial: "Learning Resource"
LearningActivity: "Learning Resource"
LessonPlan: "Content Playlist"
LessonPlanResource: "Teacher Resource"
PreviousBoardExamPapers: "Learning Resource"
TVLesson: "Explanation Content"
OnboardingResource: "Learning Resource"
ReadingMaterial: "Learning Resource"
Template: "Template"
Asset: "Asset"
Plugin: "Plugin"
LessonPlanUnit: "Lesson Plan Unit"
CourseUnit: "Course Unit"
TextBookUnit: "Textbook Unit"
Asset: "Certificate Template"
}
resourceTypeToPrimaryCategory {
Learn: "Learning Resource"
Read: "Learning Resource"
Practice: "Learning Resource"
Teach: "Teacher Resource"
Test: "Learning Resource"
Experiment: "Learning Resource"
LessonPlan: "Teacher Resource"
}
mimeTypeToPrimaryCategory {
"application/vnd.ekstep.h5p-archive": ["Learning Resource"]
"application/vnd.ekstep.html-archive": ["Learning Resource"]
"application/vnd.android.package-archive": ["Learning Resource"]
"video/webm": ["Explanation Content"]
"video/x-youtube": ["Explanation Content"]
"video/mp4": ["Explanation Content"]
"application/pdf": ["Learning Resource", "Teacher Resource"]
"application/epub": ["Learning Resource", "Teacher Resource"]
"application/vnd.ekstep.ecml-archive": ["Learning Resource", "Teacher Resource"]
"text/x-url": ["Learnin Resource", "Teacher Resource"]
}
objectcategorydefinition.keyspace="{{ lp_cassandra_keyspace_prefix }}_category_store"
#Default objectCategory mapping for channel
channel {
content{
primarycategories=["Course Assessment", "eTextbook", "Explanation Content", "Learning Resource", "Practice Question Set", "Teacher Resource", "Exam Question"]
additionalcategories= {{ content_additional_categories | default('["Classroom Teaching Video", "Concept Map", "Curiosity Question Set", "Experiential Resource", "Explanation Video", "Focus Spot", "Learning Outcome Definition", "Lesson Plan", "Marking Scheme Rubric", "Pedagogy Flow", "Previous Board Exam Papers", "TV Lesson", "Textbook"]')}}
}
collection {
primarycategories=["Content Playlist", "Course", "Digital Textbook", "Question paper"]
additionalcategories={{ collection_additional_categories | default('["Textbook", "Lesson Plan"]')}}
}
asset {
primarycategories=["Asset", "CertAsset", "Certificate Template"]
additionalcategories=[]
}
}
master.category.validation.enabled="{{ master_category_validation_enabled }}"
#Collection CSV
sunbird_dialcode_search_api="http://dial-service.{{namespace}}.svc.cluster.local:9000/dialcode/v3/list"
framework_read_api_url="{{ sunbird_content_repo_api_base_url }}/framework/v3/read"
sunbird_link_dial_code_api="{{ sunbird_content_service_api_base_url }}/collection/v4/dialcode/link"
collection {
csv {
maxRows = 6500
allowedContentTypes = ["TextBook","Collection","Course"]
maxFirstLevelUnits=30
ttl = 86400
maxUnitFieldLength=120
maxDescFieldLength=1500
contentTypeToUnitType = {"TextBook": "TextBookUnit", "Course": "CourseUnit", "Collection":"Collection"}
headers {
folderIdentifier = ["Folder Identifier"]
hierarchy = ["Level 1 Folder","Level 2 Folder","Level 3 Folder","Level 4 Folder"]
QR = ["QR Code Required?","QR Code"]
topics = ["Mapped Topics"]
collectionName = ["Collection Name"]
linkedContents = ["Linked Content 1","Linked Content 2","Linked Content 3","Linked Content 4","Linked Content 5","Linked Content 6","Linked Content 7","Linked Content 8","Linked Content 9","Linked Content 10","Linked Content 11","Linked Content 12","Linked Content 13","Linked Content 14","Linked Content 15","Linked Content 16","Linked Content 17","Linked Content 18","Linked Content 19","Linked Content 20","Linked Content 21","Linked Content 22","Linked Content 23","Linked Content 24","Linked Content 25","Linked Content 26","Linked Content 27","Linked Content 28","Linked Content 29","Linked Content 30"]
output = ["Collection Name","Folder Identifier","Level 1 Folder","Level 2 Folder","Level 3 Folder","Level 4 Folder","Description","Mapped Topics","Keywords","QR Code Required?","QR Code","Linked Content 1","Linked Content 2","Linked Content 3","Linked Content 4","Linked Content 5","Linked Content 6","Linked Content 7","Linked Content 8","Linked Content 9","Linked Content 10","Linked Content 11","Linked Content 12","Linked Content 13","Linked Content 14","Linked Content 15","Linked Content 16","Linked Content 17","Linked Content 18","Linked Content 19","Linked Content 20","Linked Content 21","Linked Content 22","Linked Content 23","Linked Content 24","Linked Content 25","Linked Content 26","Linked Content 27","Linked Content 28","Linked Content 29","Linked Content 30"]
sequence {
create = {"Level 1 Folder":0,"Level 2 Folder":1,"Level 3 Folder":2,"Level 4 Folder":3,"Description":4}
update = {"Collection Name":0,"Folder Identifier":1,"Level 1 Folder":2,"Level 2 Folder":3,"Level 3 Folder":4,"Level 4 Folder":5,"Description":6,"Mapped Topics":7,"Keywords":8,"QR Code Required?":9,"QR Code":10,"Linked Content 1":11,"Linked Content 2":12,"Linked Content 3":13,"Linked Content 4":14,"Linked Content 5":15,"Linked Content 6":16,"Linked Content 7":17,"Linked Content 8":18,"Linked Content 9":19,"Linked Content 10":20,"Linked Content 11":21,"Linked Content 12":22,"Linked Content 13":23,"Linked Content 14":24,"Linked Content 15":25,"Linked Content 16":26,"Linked Content 17":27,"Linked Content 18":28,"Linked Content 19":29,"Linked Content 20":30,"Linked Content 21":31,"Linked Content 22":32,"Linked Content 23":33,"Linked Content 24":34,"Linked Content 25":35,"Linked Content 26":36,"Linked Content 27":37,"Linked Content 28":38,"Linked Content 29":39,"Linked Content 30":40}
linkedContents = {"Linked Content 1":0,"Linked Content 2":1,"Linked Content 3":2,"Linked Content 4":3,"Linked Content 5":4,"Linked Content 6":5,"Linked Content 7":6,"Linked Content 8":7,"Linked Content 9":8,"Linked Content 10":9,"Linked Content 11":10,"Linked Content 12":11,"Linked Content 13":12,"Linked Content 14":13,"Linked Content 15":14,"Linked Content 16":15,"Linked Content 17":16,"Linked Content 18":17,"Linked Content 19":18,"Linked Content 20":19,"Linked Content 21":20,"Linked Content 22":21,"Linked Content 23":22,"Linked Content 24":23,"Linked Content 25":24,"Linked Content 26":25,"Linked Content 27":26,"Linked Content 28":27,"Linked Content 29":28,"Linked Content 30":29}
}
}
mandatory {
create = ["Level 1 Folder"]
update = ["Collection Name","Folder Identifier"]
}
}
}
plugin.media.base.url="{{ plugin_media_base_url }}"
cloudstorage {
metadata.replace_absolute_path={{ cloudstorage_replace_absolute_path | default('false') }}
relative_path_prefix={{ cloudstorage_relative_path_prefix_content }}
metadata.list={{ cloudstorage_metadata_list }}
read_base_path="{{ cloudstorage_base_path }}"
write_base_path={{ valid_cloudstorage_base_urls }}
}