Skip to content

Latest commit

 

History

History
231 lines (169 loc) · 12.6 KB

README.md

File metadata and controls

231 lines (169 loc) · 12.6 KB

Teleprompter

The server is undergoing heavy restructuring and will hopefully soon begin getting updates again

This project is very much a work in progress!!! The documentation is far from thought trough.

Config system

  • The input for the config property can be either an object or a string to a json file.
  • If the string doesn't contain a file extension, '.json' will automatically be added at the end.
  • If the string is something other than a '.json' file, the system will throw an error.
  • If the argument is not defined or false, the default value of './config.json' will be used.
  • If a file can't be found at the path provided, a new file will be created.
    • An event listener can be created to listen for when a new config file is created. It has two arguments, an error object and the path to the new file.
    • If there was an error creating the new config file and no event listeners have been added, the error will be thrown and crash the server (not able to be caught). If there is an event listener, the error will be passed to the listener instead.
  • Getters and setters are supported but have some limitations.
    • The internal observers can't be added to properties that doesn't have a setter.
    • If a properties value is updated from something other than the setter, the internal observers will have no idea that the value has been updated.
    • If a property doesn't have a getter, the system watching for file changes won't know the value and think that it is undefined.
  • Setting a property to not be configurable is not supported.
    • When a property with an observer is set to not be configurable, the system will crash.
    • If a property is not supposed to be changed, adding it as a locked property instead is recommended.

Errors (crashes the entire prompter server):

  • "Unable to setup config, 'confInput1' needs to be an object or a string path to a JSON file"
  • "Wrong file extension for '" + path + "', it needs to be a " + type + " file"
  • "Error parsing config file:" confInput1
  • "Error getting config file:" confInput1

Watching config file

  • The config file will be watched for changes.
  • To close the config watcher, at any time run the 'close' function in the '_ watcher' property on the config object.
  • Properties starting with underscore will be ignored.

Errors:

  • "Error reading contents of watched JSON file" (ERROR)
  • "Unable to parse file:", path (ERROR)
  • "Unable to add property '" + key + "' to:", path (ERROR)
  • "Unable to update property '" + key + "' in:", path (ERROR)
  • "Unable to update locked property '" + key + "' in:", path

Locked properties

A locked property is a property in the config object that can not be changed or deleted from the config object itself. It can still be changed from the argument object. Deleting the argument property will not delete the locked property so a locked property can never be unlocked.

These are for properties that a developer doesn't want an administrator to be able to change.

  • The input for the locked config properties can only be an object. Everything else will be ignored.
  • Deleting a property from the argument will not remove the property on the config object.
  • Getters are supported.
  • A property on the config object with the same name as the locked property will be written over.
  • Observers will work on the argument properties the same way they do on normal config objects.
  • Setting properties to not be configurable is not supported. Same reasons as for the config object.
  • The properties in the config object will only have a getter and therefore if the config objects property is being updated when in strict mode, an error will be thrown.

Errors:

  • "Unable to add locked properties from:", confInput2

Config properties:

When some properties are updated, they will do stuff...

  • autoLogin: Is used when no project is specified at client login. Passwords are not checked with autologin. If 'autoLogin' is false, client connecting without a specified project will get an error.

Custom Loaders:

Custom scripts are javascript files or javascript objects that load the projects and its documents...

  • A custom loader contains functions to load different types of things.
  • Loader functions can be either synchronous or asynchronous.
  • The first argument in the callback is always an error object.
  • If the server has not received a response from the loader after a set amount of time, the server will display a timeout. This does not prevent the server from receiving the data but is for... Default timeout is 1 second but can be changed in the config object with the property 'timeout'.
  • The server can only receive data once. If callbacks are called multiple times or if anything other than undefined is returned, the server will only accept the first data received.

Loader properties:

  • 'getProj' required
  • 'getProjs' optional

Errors:

Init:

  • "Invalid type, 'customLoader' in config needs to be a string path or object:", input
  • "Property '" + prop + "' in custom script has to be a function: " + func
  • "Missing property '" + prop + "' in custom script"

getProjs:

  • "Timed out getting projects to preload"
  • "List of projects to preload has already been received"
  • "Custom loader got an error in 'getProjs' when trying to get projects list"
  • "Returned value from 'getProjs' needs to be an array:", list

getProj:

  • "Timed out getting project settings for:", projID
  • "Settings for '" + projID + "' has already been received"
  • "Custom loader got an error when trying to load proj:", projID
  • "Returned value from 'getProj' needs to be an object:", settings

Server:

This is what is used for communication between the server and the clients. The argument can be formatted in many different ways.

  1. Undefined/false: This will use the port number property in the config object or the default port. It creates a new websocket server.
  2. A number: This will be used as a port number. It creates a new websocket server.
  3. An http/https server: This will use the server for communication over websockets. It creates a new websocket server with the http server.
  4. A websocket server (from nodejs module 'ws'): This will use the websocket server for communication. It only creates new listeners to the 'connections' event.
  5. A websocket server argument (for nodejs module 'ws') This will be used as is as an argument for creating a new websocket. Check documentation for 'ws' for more details. It creates a new websocket server.
  6. 'custom' as a string: This will return a function to create a new Client and is used to handle all communication outside the teleprompter server.
  • An event listener, 'socketOpen', can be added for when a new websocket server is created (applies to 1,2,3,5 only).
  • The 'close' method will close the websocket and if alternative 1 or 2 is used, it will also close the http server. If alternative 3 is used, websocket server will close while the http server will be left open. For alternative 5, see 'ws' documentation. If alternative 4 or 6 is used, the websocket server will not be closed from the 'close' method.

Notes about alternative 4 and 6:

  • Logs related to creating a new websocket server will not apply.
  • Log message for when websocket server closes will not apply.
  • Event listener 'socketOpen' is never triggered.
  • Adding static files with method 'use' will not work.

Custom 'server' (alternative 6)

  • Create a new client object for new connections with the 'createClient' function
  • Arguments are
    1. socket functions (requires a 'send' function and optional 'close' function)
    2. name of the client
    3. ip address
    • THIS ORDER IS SUBJECT TO CHANGE!!
  • The returned 'Client' object has event handlers: message, close
    • message:
      • Argument is an object or a stringified object. Data for the teleprompter server is contained in the property 'Zayght' so the socket server can be used for traffic other than for the teleprompter server.
    • close:
      • no arguments.
      • Run this when socket closes to do cleanup.
  • errors are handled manually

ERROR CODES:

  • 1000: Data received failed to parse to json or property 'Zayght' is not an object.

Authentication

  • 2000: Property 'id' in object is false/missing and autologin is disabled.

  • 2001: No projects matching requested ID.

  • 2002: Property 'pwd' is required and missing.

  • 2003: Property 'pwd' does not match stored hash.

  • 3000: Property 'id' in object is not a string.

  • 3001: Unable to hash password!!!!!

Creating a custom loader:

  • A loader can be synchronous or asynchronous.
  • They have a timeout that will only warn if the callback has not been called after a certain amount of time. This time can be changed in the 'config' file with the property 'timeout'.
  • The callback function can only be called once. Calls after the first one will be ignored.
  • If 'null' is returned, the error for wrong type will be suppressed

getProjs(list)

getProj(projID, init, conf, callback)

  • Argument projID is the id of the project and is a string.
  • Argument init is an optional value that can be sent from the client if extra data needs to be sent from the client to the getProj loader.
  • Argument conf is the config data for the entire server that is loaded at the start.
  • Argument callback is the callback that can be called in asynchronous systems.
  • The response value (second argument in callback or returned value) should be a settings object.
  • Errors can be thrown or the first argument in callback.
  • The settings object can have a property called 'hash' to define the hash to use for authenticating new clients. It has to be a hashed string from 'bcrypt.hash' or 'true'. If it is 'true', a 'hash' will be generated based on the password used.

Response

Event listeners:

  • Event listeners can be added using the 'on' method.
  • It has two arguments, an 'event' string and a callback function. If any of them are the wrong type, a 'TypeError' will be thrown.

Events

  • createConf:
    • An event that is called if the config file didn't exist and was created. If no listeners exist and the server fails to create the new config file, the server will crash instead.
    • It has three arguments, err, config object and the path to the file.
    • If it gets an error, then the config object will not have a file watched to receive updates on properties from. The config object can still be updated manually. Everything else should work as normal.
  • socketOpen:
    • Called when the server finishes creating a new websocket server.
    • No arguments.
  • preload:
    • Called when preloading projects is complete.
    • It has one argument, an object with all the connected projects.

Errors:

  • "Event needs to be a string: " + event
  • "Callback needs to be a function: " + callback
  • "No listener for event: " + event

Log

The log system prints to multiple locations.

  • By default it prints log messages to the console (tty) and two log files, one for logs and one for errors (basic).
  • These can be remapped or removed from the 'write' object in the 'log' code
  • Logs are routed to 'tty' and 'basic.log'
  • Errors are routed to 'tty' and 'basic.log' and 'basic.error'
  • Some error messages also contain an error object for more detailed information that will only show up in 'tty' and 'basic.log'
  • An html db can be created with the 'createHtmlDB' function. It will get all future messages in html style. The argument when creating the DB is the maximum number of logs to store. Default is 1000. After that number is reached, the oldes one is deleted from the database.
  • The DB returned from 'createHtmlDB' has a method called 'get'. This can be used to get all messages in one string, ready to send to the front end.
  • New messages can be added easily with the 'subscribe' function. It has the new message in html as the first argument. (To send the html to a web-browser and push new 'subscribed' messages to it, the easiest way is probably to use websockets).
  • The html logs get all log and error messages, though not the error objects.

Client stuff:

  • The name of a client can be defined in 3 ways. They are checked in this order.
    1. The 'name' argument has a value to use when the client connects. (For non-custom servers, this will be the URL query 'prefix')
    2. Does a reverse DNS lookup to find a name.
    3. Uses the 'ip' as the name if non of the above successfully got a name.
  • Every client also has an ID number. This is used to differentiate multiple connections from a single computer (or routers if open to the internet). Since it is just a rising integer, it can also be used to check how many clients have connected to the server since startup.
  • Incoming messages for the teleprompter system are contained in a property 'Sayght' and other properties are ignored. If 'Sayght' property is not defined, the incoming message will be ignored.