Compare commits

..

No commits in common. "master" and "1.0.1" have entirely different histories.

4 changed files with 11 additions and 88 deletions

View file

@ -1,52 +0,0 @@
/src
# Bootstrapping #
#################
/node_modules
/public/hot
/public/storage
/storage/*.key
/vendor
.env
.env.ini
.env.backup
.phpunit.result.cache
Homestead.json
Homestead.yaml
npm-debug.log
yarn-error.log
public/robots.txt
# OS generated files #
######################
.DS_Store
.DS_Store?
._*
.Spotlight-V100
.Trashes
Icon?
ehthumbs.db
Thumbs.db
.directory
# Tool specific files #
#######################
# vim
*~
*.swp
*.swo
# sublime text & textmate
*.sublime-*
*.stTheme.cache
*.tmlanguage.cache
*.tmPreferences.cache
# Eclipse
.settings/*
# JetBrains, aka PHPStorm, IntelliJ IDEA
.idea/*
# NetBeans
nbproject/*
# Visual Studio Code
.vscode
# Sass preprocessor
.sass-cache/

View file

@ -1,16 +1,7 @@
{ {
"name": "reflect-client", "name": "reflect-client",
"version": "1.1.2", "version": "1.0.0",
"main": "build/Reflect.js", "main": "build/Reflect.js",
"type": "module",
"exports": {
".": {
"import": {
"types": "./src/Reflect.ts",
"default": "./build/Reflect.js"
}
}
},
"devDependencies": { "devDependencies": {
"typescript": "^5.2.2" "typescript": "^5.2.2"
} }

View file

@ -1,7 +1,4 @@
import { Method } from "./Method.js"; import { Method } from "./Method";
// Export Method as importable directly from the Reflect.js ESM
export { Method };
// Connect to a Reflect API instance over HTTP // Connect to a Reflect API instance over HTTP
export default class Client { export default class Client {
@ -9,8 +6,7 @@ export default class Client {
private headers: object = {}; private headers: object = {};
constructor(url: string, key: string|null = null) { constructor(url: string, key: string|null = null) {
// Append tailing slash if omitted from URL string this.url = url;
this.url = url.substring(url.length - 1) === "/" ? url : url + "/";
// Use API key with requests if defined // Use API key with requests if defined
if (key) { if (key) {
@ -18,22 +14,9 @@ export default class Client {
} }
} }
// Set request header
private setHeader(name, value): void {
return this.headers[name] = value;
}
// Set API key to use for all requests // Set API key to use for all requests
private setApiKey(key: string): void { private setApiKey(key: string): void {
return this.setHeader("Authorization", `Bearer ${key}`); this.headers["Authentication"] = `Bearer ${key}`;
}
// Get fully qualified URL to endpoint
private getEndpoint(endpoint: string): string {
// Remove leading slash if provided for pathname. It's already set on the domain name
endpoint = endpoint.substring(0, 1) !== "/" ? endpoint : endpoint.substring(1, endpoint.length);
return this.url + endpoint;
} }
// Call a Reflect API endpoint with method and optional payload // Call a Reflect API endpoint with method and optional payload
@ -43,13 +26,12 @@ export default class Client {
headers: this.headers headers: this.headers
} }
// JSON stringify and append body to request if provided and is not a GET request // JSON stringify and append body to request if provided
if (payload && method !== Method.GET) { if (payload) {
this.setHeader("Content-Type", "application/json");
options["body"] = JSON.stringify(payload); options["body"] = JSON.stringify(payload);
} }
// Fetch and return Response object // Fetch and return Response object
return await fetch(this.getEndpoint(endpoint), options); return await fetch(endpoint, options);
} }
} }

View file

@ -2,7 +2,9 @@
"compilerOptions": { "compilerOptions": {
"emitDecoratorMetadata": true, "emitDecoratorMetadata": true,
"experimentalDecorators": true, "experimentalDecorators": true,
"module": "NodeNext", "module": "amd",
"outDir": "./build" "target": "ES6",
"rootDir": "./src",
"outFile": "./build/Reflect.js"
} }
} }