Skip to content

An instance of the CWRC-Writer configured to interact the CWRC-GithubServer which in turn uses Github for document, annotation, and schema storage.

Notifications You must be signed in to change notification settings

bucknellu/CWRC-GitWriter

 
 

Repository files navigation

CWRC-GitWriter

Picture

experimental

  1. Overview
  2. Use
  3. Installation
  4. Development
  5. Authentication
  6. Contributing
  7. License

The code in this repository serves two purposes:

  1. To back the sandbox deployment: https://cwrc-writer.cwrc.ca/
  2. To provide an example configuration of the CWRC-Writer for those who might like to substitute a different storage or lookup system.

Table of Contents

  1. To back the sandbox deployment https://cwrc-writer.cwrc.ca
  2. To provide an example configuration of the CWRC-Writer for those who might like to substitute a different backend (e.g., database, file system on server, different entity lookup.)

Use

A running deployment of the code in this repository is available for anyone's use at:

https://cwrc-writer.cwrc.ca

Overview

High Level Overview

As you can see from the overview diagram, CWRC-GitWriter is the parent package which collects and configures the various child packages. While CWRC-WriterBase provides the primary editing functionality, it requires both storage and entity lookup packages, which in this case are cwrc-git-dialogs and CWRC-PublicEntityDialogs.

Although the sandbox version provides a freely usable instance, you may of course install an instance of the CWRC-GitWriter on your own server. CWRC-GitWriter also requires a running instance1 of CWRC-GitServer, which in turn interacts with GitHub through the GitHub API.

Although the sandbox version provides a freely usable instance, you may of course install an instance of the CWRC-GitWriter on your own server. CWRC-GitWriter also requires a running instance of CWRC-GitServer, which in turn interacts with GitHub through the GitHub API.

Note that if you want to create a new version of the CWRC-Writer that is configured to work with your own document repository (e.g., a database), this repository still provides you with the best example to follow. You'll also want to look at the cwrc-git-dialogs repository, which holds the javascript class that handles calls to the backend storage, in this case to Github via the CWRC-GitServer. This is the class you'd want to replace with your own. To replace the entity lookups you'd replace cwrc-public-entity-dialogs

Building

There are two approached to install the sandbox version of the CWRC-GitWriter.

  1. Install the dockerized verion of Git-Server/Git-Writer. The instruction for this approach is descibed in the CWRC-GitWriter-Docker repo.

  2. Manually install each component. Instruction is down below:

This repository contains a JS file — the app file, and a JSON file — the config file. The app file does not contain much code itself; it's main purpose to load/require other code bases, and then configure and instantiate the CWRC-Writer. It must first be built in order to be useable. To build:

  • Download the code for this repository, or clone the repository
  • Install all the NPM package dependencies: npm install
  • Use Webpack to package it up for deployment: npm run build

The built code resides in the newly created build directory. It contains the app, along with all the necessary CSS, XML, and image files. To deploy the CWRC-GitWriter simply copy the build directory to your server, probably the same server from which you'd serve the CWRC-GitServer. You might choose to use ftp, scp, rsync, etc. An example rsync command might be:

Alternately, if your server has Git and npm support you can clone and build this repository directly on your server.

Development

Using this code as an example to build a CWRC-Writer with a different backend

The code in this repository brings together and configures code from other repositories and wouldn't in itself typically be usefully modified. You could, however, clone this repository as a base from which to create a new configuration of the CWRC-Writer, or simply use the code here as a guide in creating your own configuration. Your configuration might, for example, use Fedora to store documents, rather than GitHub.

npm and Browserify

The code in this repository simply brings together and configures code from other repositories and wouldn't in itself typically be usefully modified. You could, however, clone this repository as a base from which to create a new configuration of the CWRC-Writer, or simply use the code here as a guide in creating your own configuration. Your configuration might, for example, use Fedora to store documents, rather than GitHub.

CWRC-GitWriter uses NPM both for dependency management and for running it's main build script. The build script in turn uses Webpack to bundle all code into the single build/js/app.js file. The package.json file contains the script for invoking Webpack as well as the full list of NPM packages required.

The entry point into the CWRC-GitWriter code, on which Webpack is invoked, is src/js/app.js which uses node.js module loading to 'require' - either from the NPM public registry or from local files - the bits and pieces that make up the CWRC-GitWriter, and plug them together. Webpack resolves all the 'require' statements, and bundles all the code, including NPM packages and local files, into a single javascript file that is loaded into the web browser.

To develop a new configuration of the CWRC-Writer, you'll therefore need to understand NPM and Webpack. Then you can get into the CWRC-GitWriter NPM package.json file and src/js/app.js and adapt it to your own project.

The src/js/app.js file imports the following npm CWRC packages:

  • CWRC-WriterBase

    The CWRC-Writer editor

  • cwrc-git-dialogs

    The javascript class that handles calls to the backend storage, in this case to Github via the CWRC-GitServer.2 This is the class you'd want to replace with your own.

  • cwrc-public-entity-dialogs

    The javascript class that handles lookups of named entities. You may want to replace this with your own entity lookup

The app.js file also imports a config file:

  • src/js/config.js

    A javascript object that describes the XML schemas supported, and is used to pass in other objects to the CWRC-Writer.

The src/js/app.js file ties all these together as you would for your own configuration of the CWRC-Writer.

Note that the authentication for Github is invoked in app.js since it redirects to the GitHub site if the user isn't loaded. Better to redirect here at the outset before loading up all the other CWRC related code. Read more about authentication below in the Authentication Section

If you are making changes to the npm packages that contribute to the GitWriter (or more likely to some custom instance of the GitWriter that you've built) and you find yourself repeatedly packaging and publishing the NPM packages and reimporting the newly published packages (e.g.,npm i cwrc-writer-base@latest) then you can instead point the package.json dependencies at the local instances, like so:

"dependencies": {
   "cwrc-git-dialogs": "file:///Users/jc/Dropbox/cwrc/github/cwrc-git-dialogs",
    "cwrc-public-entity-dialogs": "file:///Users/jc/Dropbox/cwrc/github/CWRC-PublicEntityDialogs",
    "cwrc-writer-base": "file:///Users/jc/Dropbox/cwrc/github/CWRC-WriterBase",
    "jquery": "3.1.0",
    "jquery-ui": "1.12",
    "js-cookie": "2.1.3"
  }

If you are making changes to the npm packages that contribute to the CWRC-GitWriter (or more likely to some custom instance of the CWRC-GitWriter that you've built) and you find yourself repeatedly packaging and publishing the npm packages and re-importing the newly published packages (e.g.npm i cwrc-writer-base@latest) then you can instead use npm link to point the package.json dependencies at the local instances.

For example, when developing cwrc-git-dialogs you would use:

Once finished making and testing local changes, publish the new NPM packages, including the local packages, and remove the dependencies from package.json:

```json
"dependencies": {
    "jquery": "3.1.0",
    "jquery-ui": "1.12",
    "js-cookie": "2.1.3"
  }

This creates a symbolic link between the two packages on your computer. Then, when you run npm run watch from CWRC-GitWriter, changes made to cwrc-git-dialogs will cause the CWRC-GitWriter build to update.

After completing the changes to cwrc-git-dialogs and publishing it to npm, you would then use npm unlink to remove the symbolic link:

cd ~/projects/CWRC-GitWriter
npm unlink cwrc-git-dialogs
npm i cwrc-git-dialogs@latest

NOTE: another alternative to working with local packages is npm link

Authentication

Authentication is with Github using OAuth, as described in the Github API docs:

Github - building oauth apps

The two relevant steps there are

Creating an OAuth App

and the section called Web Application Flow in:

Authorizing OAuth Apps

After authenticating with Github, Github returns an OAuth token, which is then submitted on every request to the Github API.

Authentication is done with GitHub using OAuth, as described in the GitHub developer docs.

The two relevant steps there are:

  1. Creating an OAuth App
  2. The section called Web Application Flow in Authorizing OAuth Apps

After authenticating with GitHub, GitHub returns an OAuth token, which is then submitted on every request to the GitHub API.

We could store this token in a server side session, but instead we store it in a browser cookie that the CWRC-GitWriter submits in the request header (to help guard against CSRF) for each request to the CWRC-GitServer.

As explained in the development section you wouldn't typically usefully modify anything here for use by others. Nevertheless, if there is something we've missed, please submit an Issue. If you are interested, however, please take a look at our Development Docs

License

GNU GPL V2

About

An instance of the CWRC-Writer configured to interact the CWRC-GithubServer which in turn uses Github for document, annotation, and schema storage.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 91.4%
  • HTML 6.4%
  • Dockerfile 2.2%