]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - server/initializers/constants.js
Try to make a better communication (between pods) module
[github/Chocobozzz/PeerTube.git] / server / initializers / constants.js
index bb141456aba2919d75e11dbd5a0dbdeb2d908833..caeb340cffffaa7d002979b8a1feb715c032ab23 100644 (file)
@@ -6,8 +6,11 @@ const API_VERSION = 'v1'
 // Score a pod has when we create it as a friend
 let FRIEND_BASE_SCORE = 100
 
-// Time to wait between requests to the friends
-let INTERVAL = 60000
+// Time to wait between requests to the friends (10 min)
+let INTERVAL = 600000
+
+// Number of results by default for the pagination
+const PAGINATION_COUNT_DEFAULT = 15
 
 // Number of points we add/remove from a friend after a successful/bad request
 const PODS_SCORE = {
@@ -15,8 +18,21 @@ const PODS_SCORE = {
   BONUS: 10
 }
 
-// Number of retries we make for the make retry requests (to friends...)
-let REQUEST_RETRIES = 10
+// Number of requests in parallel we can make
+const REQUESTS_IN_PARALLEL = 10
+
+// Number of requests to retry for replay requests module
+const RETRY_REQUESTS = 5
+
+// Sortable columns per schema
+const SEARCHABLE_COLUMNS = {
+  VIDEOS: [ 'name', 'magnetUri', 'podUrl', 'author', 'tags' ]
+}
+
+// Sortable columns per schema
+const SORTABLE_COLUMNS = {
+  VIDEOS: [ 'name', '-name', 'duration', '-duration', 'createdDate', '-createdDate' ]
+}
 
 // Videos thumbnail size
 const THUMBNAILS_SIZE = '200x110'
@@ -24,11 +40,22 @@ const THUMBNAILS_SIZE = '200x110'
 // Path for access to thumbnails with express router
 const THUMBNAILS_STATIC_PATH = '/static/thumbnails'
 
+const VIDEOS_CONSTRAINTS_FIELDS = {
+  NAME: { min: 3, max: 50 }, // Length
+  DESCRIPTION: { min: 3, max: 250 }, // Length
+  MAGNET_URI: { min: 10 }, // Length
+  DURATION: { min: 1, max: 7200 }, // Number
+  AUTHOR: { min: 3, max: 20 }, // Length
+  TAGS: { min: 1, max: 3 }, // Number of total tags
+  TAG: { min: 2, max: 10 }, // Length
+  THUMBNAIL: { min: 0, max: 20000 } // Bytes
+}
+
 // Special constants for a test instance
 if (isTestInstance() === true) {
   FRIEND_BASE_SCORE = 20
   INTERVAL = 10000
-  REQUEST_RETRIES = 2
+  VIDEOS_CONSTRAINTS_FIELDS.DURATION.max = 14
 }
 
 // ---------------------------------------------------------------------------
@@ -37,10 +64,15 @@ module.exports = {
   API_VERSION: API_VERSION,
   FRIEND_BASE_SCORE: FRIEND_BASE_SCORE,
   INTERVAL: INTERVAL,
+  PAGINATION_COUNT_DEFAULT: PAGINATION_COUNT_DEFAULT,
   PODS_SCORE: PODS_SCORE,
-  REQUEST_RETRIES: REQUEST_RETRIES,
+  REQUESTS_IN_PARALLEL: REQUESTS_IN_PARALLEL,
+  RETRY_REQUESTS: RETRY_REQUESTS,
+  SEARCHABLE_COLUMNS: SEARCHABLE_COLUMNS,
+  SORTABLE_COLUMNS: SORTABLE_COLUMNS,
   THUMBNAILS_SIZE: THUMBNAILS_SIZE,
-  THUMBNAILS_STATIC_PATH: THUMBNAILS_STATIC_PATH
+  THUMBNAILS_STATIC_PATH: THUMBNAILS_STATIC_PATH,
+  VIDEOS_CONSTRAINTS_FIELDS: VIDEOS_CONSTRAINTS_FIELDS
 }
 
 // ---------------------------------------------------------------------------