Skip to content

Commit

Permalink
Improve Docs (#264)
Browse files Browse the repository at this point in the history
* docs (README): rename existing README and start fresh

* docs (README): add section "Getting Started"

* docs (README): add more explanations

* docs (README): remove blank lines

* docs (README): small adaptions

* docs (typedoc): change options

* docs (typedoc): change options

* docs (typedoc): change options

* docs (typedoc): change options, flag constructs as internal

* docs (typedoc): flag internally used constructs as @internal

* docs (typedoc): flag internally used constructs as @internal

* docs (typedoc): flag internally used constructs as @internal

* docs (typedoc): flag internally used constructs as @internal

* docs (typedoc): use the @category tag

* docs (typedoc): use the @category tag

* docs (typedoc): use the @category tag

* docs (typedoc): use the @category tag

* docs (typedoc): use the @category tag

* docs (typedoc): use the @category tag

* docs (typedoc): use JSON file for config

* docs (typedoc): use the @category tag

* docs (typedoc): use the @category tag

* docs (README): small improvements

* docs (dev docs): reorganize dev docs

* docs (dev docs): explain dev version

* docs (dev docs): explain test data integration

* docs (dev docs): explain updating DSP-API releases

* docs (test framework): explain how to integrate a local build

* docs (test framework): small fix

* docs (old README): remove old README

* docs (README etc.): small improvements

* docs (v2): add missing docstrings

* docs (contribute): add link to general contribution guidelines

* docs (contribute): improve note on dev version build script

* docs (README): link to npm packages

* docs (contribution.md): remove space

* docs (contribution.md): add full stop

* docs (contribution.md): use DSP-API consistently

* docs (README): fix typo

* docs (README): mention desig-documentation.md

* docs (README): clarify script description

* docs (README): fixes

* docs (contribution): fixes

* docs (design docs): fixes

* docs (README): links

* docs (README): links

* docs (metadata endpoint): use @category tag

Co-authored-by: André Kilchenmann <a.kilchenmann@dasch.swiss>
  • Loading branch information
tobiasschweizer and André Kilchenmann authored Dec 3, 2020
1 parent 52b66fc commit 95c57c3
Show file tree
Hide file tree
Showing 211 changed files with 1,112 additions and 401 deletions.
227 changes: 60 additions & 167 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,202 +1,95 @@
# DSP-JS-LIB &mdash; A library to easily connect to Knora/DSP API
# DSP-JS-LIB &mdash; A library to easily connect to DSP-API (Knora)

[![npm version](https://badge.fury.io/js/%40dasch-swiss%2Fdsp-js.svg)](https://www.npmjs.com/package/@dasch-swiss/dsp-js)
[![CI](https://github.com/dasch-swiss/knora-api-js-lib/workflows/CI/badge.svg)](https://github.com/dasch-swiss/dsp-js-lib/actions?query=workflow%3ACI)
[![npm downloads](https://img.shields.io/npm/dt/@dasch-swiss/dsp-js.svg?style=flat)](https://www.npmjs.com/package/@dasch-swiss/dsp-js)
[![minzipped size](https://img.shields.io/bundlephobia/minzip/@dasch-swiss/dsp-js.svg?style=flat)](https://www.npmjs.com/package/@dasch-swiss/dsp-js)
[![license](https://img.shields.io/npm/l/@dasch-swiss/dsp-js.svg?style=flat)](https://www.npmjs.com/package/@dasch-swiss/dsp-js)

## Purpose of this project
## Introduction

This TypeScript library allows a developer to connect to the Knora API without knowing technical details about it.
We published this library as `@dasch-swiss/dsp-js` on NPM for easy integration into TypeScript/JavaScript projects.
The library is developed in TypeScript and declaration files are part of the package to allow for integration with other TypeScript projects.
### Links in this document
This document contains links to other files of DPS-JS-LIB's documentation.
Note that these links point to the latest version of these files and
not necessarily the version you are working with.

## Changelog
### Purpose of DSP-JS-LIB
The purpose of DSP-JS-LIB is to facilitate the communication with [DSP-API (Knora)](https://www.knora.org) in web clients developed with TypeScript/JavaScript.
DSP-JS-LIB depends on [RxJS](https://rxjs.dev/guide/overview) and is web framework agnostic (it can be used with Angular, React, Vue.js etc.).

See file <https://github.com/dasch-swiss/dsp-js-lib/releases>.
DSP-JS-LIB offers the following features:
- handling of HTTP calls to connect to DSP-API
- (de)serialisation from and to JSON-LD so the web client can work with classes instead
- methods that combine different HTTP calls to DSP-API into *one* method call
- caching for different types of data so fewer HTTP calls to DSP-API have to be performed

## Getting started

### Requirements
### Basic Structure of DSP-JS-LIB
DSP-JS-LIB's architecture is based on endpoints that correspond to DSP-API's endpoints.

This library has been written to be used in any TypeScript/JavaScript project.
It may be integrated with any JavaScript framework/library of your choice, such as Angular, React, Vue.js, and more.
The following endpoints are available through DSP-JS-LIB:
- **admin**: getting and modifying users, projects, permissions etc.
- **v2**: requesting and modifying resources and values using DSP-API version 2
- **system**: DSP-API's health status

We recommend to install this library through NPM. This will make sure that all dependencies are installed.
At the moment, this library depends on `rxjs`, `json2typescript`, and `jsonld`.
Consult the API docs for more details about the available endpoints.
See [design documentation](design-documentation.md) for a detailed description of DSP-JS-LIB's design and architecture.

In order to be able to integrate this library, you should have a basic understanding of an `Observable`.
All HTTP requests to Knora are performed using an `Observable` through the RxJS library.
### RxJS Observables
DSP-JS-LIB's endpoints return observables to the client.
An `Observable` represents the result of an asynchronous request to DSP-API that will either succeed or fail.
An `Observable` is an [RxJS construct](https://rxjs.dev/guide/observable) that the client can subscribe to.

### Installation
## Getting started

Run `npm install @dasch-swiss/dsp-js --save` in the root directory of your project.
Make sure to install the lib's peer dependencies, see below.
### Install DSP-JS-LIB
Run `npm install @dasch-swiss/dsp-js --save` to install DSP-JS-LIB in your npm project.

### Dependencies and Peer Dependencies
DSP-JS-LIB depends on [jsonld](https://www.npmjs.com/package/jsonld) and [json2typescript](https://www.npmjs.com/package/json2typescript).
These dependencies will be installed with `npm install`.

This library depends on `RxJS`, `jsonld`, and `json2typescript`. `jsonld` and `json2typescript` are only used internally and listed as dependencies.

`RxJS` is listed as a peer dependency and **not** installed with `npm install`.
It can be installed with `npm run peer-deps` when you are working on this project.
`RxJS`'s `Observable` is used in this library's public API
and has to be compatible with whatever version of `RxJS` is used in the productive environment, e.g. an Angular application.
This library works with `RxJS`'s major version defined in `package.json` . See `rxjs.md` for details.

### Starting example
[RxJS](https://www.npmjs.com/package/rxjs) is a peer dependency of this library and is **not installed** when running `npm install`.
Note that DSP-JS-LIB requires major version 6 of `rxjs`.

Below you may find a minimal example in TypeScript for the process of the user login.
Make sure that the framework you are using, e.g., Angular, requires major version 6 of RxJS to ensure the peer dependency will be met.
Otherwise, install it with `npm install rxjs@6.x --save`.

If your IDE does not automatically help you with imports, these are the necessary files for the basic example:
### Start Using DSP-JS-LIB
In order to get started using DSP-JS-LIB, you have to create a `KnoraApiConfig` instance and pass it to `KnoraApiConnection`'s constructor:

```typescript
import { KnoraApiConfig, KnoraApiConnection, ApiResponseData, ApiResponseError, LoginResponse } from "@dasch-swiss/dsp-js";
```

Now, we will set up an instance of the class `KnoraApiConnection`.
This instance can be your gateway to all API requests.
In most use cases, you will want to store this instance globally within your JavaScript application.
// import from DSP-JS-LIB
import { KnoraApiConfig, KnoraApiConnection } from "@dasch-swiss/dsp-js";

```typescript
// Set up a KnoraApiConnection instance.
// We suggest to do this at your app entrypoint and store the instance globally.
// create the configuration
const config: KnoraApiConfig = new KnoraApiConfig("https", "api.dasch.swiss");

const config: KnoraApiConfig = new KnoraApiConfig("https", "knora.org");
// create a connection instance
const knoraApiConnection: KnoraApiConnection = new KnoraApiConnection(config);
```

As soon as the basic configuration is done, you will be able to use the pre-defined methods provided by the KnoraApiConnection instance.
For example, you can login a user with a password as follows:
Once you have set up the connection instance, you can use any of DSP-JS-LIB's endpoints to perform requests to DSP-API.
In the following example, we are requesting a resource from DSP-API:

```typescript
// Login the user to Knora.
// The method subscribe() is provided with two anonymous functions:
// The first is launched in case of success, the second in case of failure.

knoraApiConnection.v2.auth.login("user", "password").subscribe(
(response: ApiResponseData<LoginResponse>) => {
console.log("Login successful!");
},
(response: ApiResponseError) => {
console.error("Login failed!");
}
// request a resource using the resources endpoint from v2
knoraApiConnection.v2.res.getResource(iri).subscribe(
(resource: ReadResource) => {
// "resource" represents a resource retrieved from DSP-API
console.log(res);
},
(error) => {
// if, for some reason, the request failed
console.error(error);
}
);
```

Our library makes sure that session data (token) is stored within the KnoraApiConnection instance.
Any subsequent call after a successful login will be performed using the session.

### Test environment for Angular

`./test-framework` provides a ready-to-use test environment for Angular developers. See `./test-framework/README.md` for further instructions.

## Scripts for testing and deployment

This package provides the following short-hand scripts:

1. `npm run peer-deps`: Installs the project's peer dependencies. Peer dependencies are not installed with `npm install`, but have to be met before building or running the tests.
1. `npm run test`: Runs the project's tests defined in `./karma.conf.js`. The coverage data is saved into the `./coverage/` folder.
1. `npm run build`: Builds the whole project without testing and puts the files into the `./build/` folder.
1. `npm run yalc-publish`: Executes 2 and publishes the package to the yalc app store.
1. `npm run npm-pack`: Executes 1, 2 and packs the `./build/` folder into an NPM tgz package. The package is moved into a `./dist/` folder.
1. `npm run npm-publish`: Executes 4 and publishes the package to the NPM store (runs in dry-run mode).

> Note: You need to install [`yalc`](<https://www.npmjs.com/package/yalc>) globally by `npm install yalc -g` to use script number 4.
For further development with Knora, the following scripts can be used:

1. `npm run integrate-admin-test-data <path-to-generated-client-code>`: integrates generated test data for the Knora Admin API,
see <https://docs.knora.org> -> Internals -> Development -> Generating Client Test Data.
1. `npm run integrate-v2-test-data <path-to-generated-client-code>`: integrates JSON-LD test data for Knora API v2,
see <https://docs.knora.org> -> Internals -> Development -> Generating Client Test Data.
The test data files have to be added to `scripts/v2-test-data-config.json`: `source` refers to their location in the Knora test data directory structure,
`destination` refers to their location in this repo. The test data files are copied when running the script.
1. `npm run expand-jsonld-test-data`: creates versions with expanded prefixes for Knora API v2 JSON-LD test data.
1. `npm run prepare-dev-publication`: prepares a dev version of the library for publication.
The dev versions contains mocks that produce tests data without a connection to Knora.
The mocks are configured in `scripts/mock-exports.json`.
If you need a local version of this lib that contains the mocks, do the following:
- `npm run prepare-dev-publication` to prepare a dev version.
- `npm run yalc-publish` to publish a local build containing the mocks.
1. `npm run webdriver-update` (from directory `test-framework`): updates Chrome webdriver for e2e tests

## Change Supported Version of DSP-API

DSP-JS is compatible with a specified release of DSP-API.
To update the target release of DSP-API, the following steps have to be carried out:

1. Update DSP-API version in
- `vars.mk`, e.g., change `v13.0.0-rc.16` to `v13.0.0-rc.17`.
- `src/api/system/health/health-endpoint.spec.ts`
1. Delete local test data with `make delete-test-data`
1. Generate test data using the target DSP-API release,
- Variant 1: See <https://docs.knora.org> -> Internals -> Development -> Generating Client Test Data
and copy generated test data from Knora-Api repository to DSP-JS-Lib repo:
Run from project root: `cp /Folder/To/Knora-Api/client-test-data.zip ./`
- Variant 2: Download test-data from DSP-API release with `make get-test-data-from-release`
1. Unpack generated test data and integrate it with `make prepare-test-data`
1. Run the unit tests with `npm test` from the project root.
1. Check for differences in the generated test data with respect to the previous release of DSP-API.
If there are changes in the test data that have **no breaking effect**, integrate them (add them to the git repo).
Otherwise, DSP-JS has to be adapted to comply with the later version of DSP-JS. Also see section "Integration of Generated Test Data".
1. Run the e2e tests against the target release of DSP-API:
- prepare the local publication of the library using `npm run prepare-dev-publication`
- build the library and publish it locally with `npm run yalc-publish`
- change to directory `test-framework`
- add the locally build library using `npm run yalc-add` and run `npm install`
- run `npm run webdriver-update` and then `npm run e2e`
1. See if the tests pass on GitHub CI

## Integration of Generated Test Data

By default, all generated test data for THE admin API is integrated with the script `npm run integrate-admin-test-data`.

Test data for v2 has to be added to `scripts/v2-test-data-config.json` to be used in the unit tests.
All files that are contained in `scripts/v2-test-data-config.json` will be copied this library's tests data when running `npm run integrate-v2-test-data`.

Example:

```json
{
"generated-test-data": [
{
"source": "/v2/ontologies/all-ontology-metadata-response.json",
"destination": "./test/data/api/v2/ontologies/all-ontology-metadata-response.json"
},
...
]
}
```

The example shown above will copy the file `/v2/ontologies/all-ontology-metadata-response.json`
from the generated test data to the specified destination in this library's test data folder.
In the unit tests, this file can then be used to mock request and response data.

When adding a new method to a v2 endpoint, only add the test data needed to test this method to facilitate the review process.
**Do not add v2 test data that is not used in the unit tests.**

After integrating v2 test data, run `npm run expand-jsonld-test-data`.

## Publish a new version to NPM

Before publishing:

- Update README if necessary and commit the changes.

- Be sure that the dependency to DSP-API is set to the correct version:
- Update DSP-API version in `Makefile` (see section above)

A new version will be published with each Github release as it's part of Github actions' workflow. To make a new release, go to <https://github.com/dasch-swiss/dsp-js-lib/releases> and update the draft called "Next release" by changing:

- the tag version and the release title (same name) with the version number, e.g. `v3.0.0` or `v3.0.0-rc.0`
- If this is a pre-release, check the box "This is a pre-release"

New package will be available on <https://www.npmjs.com/package/@dasch-swiss/dsp-js>.

At the moment (2020-06) all releases contain mocked data.
For more information about available endpoints and methods, consult the API docs.

## Documentation
## Release Notes
For the release notes
see [GitHub releases](https://github.com/dasch-swiss/dsp-js-lib/releases).

For the public API, see <https://dasch-swiss.github.io/dsp-js-lib>.
For design documentation, see file `design-documentation.md`.
## Developing DSP-JS-LIB
See [contribution guidelines](contribution.md).
Loading

0 comments on commit 95c57c3

Please sign in to comment.