Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
This repository contains draft standards of Uniform Resource Locators for the Fidonet Global Hypertext Interface project.
The FidoURL.txt
file is the English version of the draft.
The FidoURL.rus.txt
file is the Russian version of the draft. This version is provided in UTF-8 (for the diffs to look reasonably good on GitHub and other git tools) and thus should be converted to CP866 encoding (common in Russian Fidonet) before posting to Fidonet.
This repository does also contain a JavaScript module (for Node.js) as a proof of concept and a reference implementation. It requires Node.js version 0.8 (or newer) and npm. An attempt of an npm-driven installation in Node 0.6 (or older) would fail in 2014 anyway.
Both drafts of the standards are “nightly builds” of 0.5pre version, dated 8 Apr 2010 (and after that date any regular updating of the 0.5pre drafts was abandoned).
The JavaScript module is compatible with the drafts (though not completely covered by tests to prove that). The module also contains some additional features from the FGHI TODO list (circa 2010, and not included in this repository), these are not yet documented formally in the drafts.
Latest packaged version: npm install fghi-url
Latest githubbed version: npm install https://github.com/Mithgol/FGHI-URL/tarball/master
You may visit https://github.com/Mithgol/FGHI-URL occasionally to read the latest README
and the drafts of the FGHI URL standard. The package's version is planned to grow after code changes only. (And npm publish --force
is forbidden nowadays.)
When you require()
the installed module, an URL parser function is returned.
You may call that function (with some FGHI URL as its only parameter), and it returns an object with properties that correspond to parts of the given URL.
(An URL parser function is actually that object's constructor, but using the word new
is optional.)
Example:
The returned object has the following properties:
scheme
— The name of the given FGHI URL's scheme (one of the documented: 'netmail'
, 'areafix'
, 'echomail'
, 'area'
, 'faqserv'
, 'fecho'
, 'freq'
).
schemeSpecificPart
— The rest of the URL (everything after the separator that followed the scheme). The meaning of its contents is specific to the given scheme.
requiredPart
— The required part of the URL (everything before the first ?
character in schemeSpecificPart
; or the entire schemeSpecificPart
, if there's no ?
).
optionalPart
— The optional part of the URL (everything after the first ?
character; an empty string, if there's no ?
).
optionalParams
— An array of optional parameters encountered in optionalPart
. Each parameter is an object that has two properties (name
and value
).
request
— The request (for faqserv://…
URLs only; empty for URLs of other types).
station
— The address of the target station in Fidonet.
stationZone
, stationNet
, stationNode
, stationPoint
, stationDomain
— Parts of the 5D station
address.
objectPath
— The path to a designated object (if any).
objectPathParts
— Array of the parts of that path (that were slash-separated in objectPath
). If objectPath
ends with a slash, the last element of the array is '/'
.
echoNames
— An array of the fully-qualified names of Fidonet echomail areas. Each element is also an array and contains parts of such name (that were @
-separated in the URL).
If an error is encountered, the parser throws new Error('…')
with one of the ten predefined strings (error descriptions). You may see these strings in the bottom of index.js
.
The returned object also has following methods:
Returns true
if the object's scheme
is "area"
and its optionalPart
contains at least one filter.
Returns false
otherwise. For area://…
URLs it means that the designated object is the whole area(s) unless objectPath
is given.
Accepts supportedViews
(the list of views supported by a browser) in a form of a string (such as 'list totr'
, where view tokens are space-separated) or an array of string (such as ['list', 'totr']
). If several views are supported, their tokens must be given in the order of preference.
Returns the token of an URL-recommended view (if the given URL recommends a browser-supported view) or an empty string.
If several supported views are recommended, the most preferred view's token is returned. For example,
require('fghi-url')('area://Example?view=list+tree+sing').getView('sing cale tree')
returns 'tree'
(that is the most preferred of the URL's recommendations supported by the browser),
require('fghi-url')('area://Example?view=tree&view=sing').getView('sing cale tree')
returns 'sing'
(among the equally preferred recommendations of the URL that was the most preferred by the browser).
It is necessary to install Mocha and JSHint for testing.
You may install Mocha globally (npm install mocha -g
) or locally (npm install mocha
in the directory of the FGHI URL module).
You may install JSHint globally (npm install jshint -g
) or locally (npm install jshint
in the directory of the FGHI URL module).
After that you may run npm test
(in the directory of the FGHI URL module) for testing.
Distribution of the FGHI URL standards is unlimited (see section 1), provided that the text is not altered without notice.
The JavaScript code is MIT-licensed (see the LICENSE
file).
FAQs
FGHI URL parser
The npm package fghi-url receives a total of 5 weekly downloads. As such, fghi-url popularity was classified as not popular.
We found that fghi-url demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.