Implements Phases 1-8 of the TFTSR implementation plan. Rust backend (Tauri 2.x, src-tauri/): - Multi-provider AI: OpenAI-compatible, Anthropic, Gemini, Mistral, Ollama - PII detection engine: 11 regex patterns with overlap resolution - SQLCipher AES-256 encrypted database with 10 versioned migrations - 28 Tauri IPC commands for triage, analysis, document, and system ops - Ollama: hardware probe, model recommendations, pull/delete with events - RCA and blameless post-mortem Markdown document generators - PDF export via printpdf - Audit log: SHA-256 hash of every external data send - Integration stubs for Confluence, ServiceNow, Azure DevOps (v0.2) Frontend (React 18 + TypeScript + Vite, src/): - 9 pages: full triage workflow NewIssue→LogUpload→Triage→Resolution→RCA→Postmortem→History+Settings - 7 components: ChatWindow, TriageProgress, PiiDiffViewer, DocEditor, HardwareReport, ModelSelector, UI primitives - 3 Zustand stores: session, settings (persisted), history - Type-safe tauriCommands.ts matching Rust backend types exactly - 8 IT domain system prompts (Linux, Windows, Network, K8s, DB, Virt, HW, Obs) DevOps: - .woodpecker/test.yml: rustfmt, clippy, cargo test, tsc, vitest on every push - .woodpecker/release.yml: linux/amd64 + linux/arm64 builds, Gogs release upload Verified: - cargo check: zero errors - tsc --noEmit: zero errors - vitest run: 13/13 unit tests passing Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
139 lines
4.4 KiB
Markdown
139 lines
4.4 KiB
Markdown
# hosted-git-info
|
|
|
|
This will let you identify and transform various git hosts URLs between
|
|
protocols. It also can tell you what the URL is for the raw path for
|
|
particular file for direct access without git.
|
|
|
|
## Example
|
|
|
|
```javascript
|
|
const hostedGitInfo = require("hosted-git-info")
|
|
const info = hostedGitInfo.fromUrl("git@github.com:npm/hosted-git-info.git", opts)
|
|
/* info looks like:
|
|
{
|
|
type: "github",
|
|
domain: "github.com",
|
|
user: "npm",
|
|
project: "hosted-git-info"
|
|
}
|
|
*/
|
|
```
|
|
|
|
If the URL can't be matched with a git host, `null` will be returned. We
|
|
can match git, ssh and https urls. Additionally, we can match ssh connect
|
|
strings (`git@github.com:npm/hosted-git-info`) and shortcuts (eg,
|
|
`github:npm/hosted-git-info`). GitHub specifically, is detected in the case
|
|
of a third, unprefixed, form: `npm/hosted-git-info`.
|
|
|
|
If it does match, the returned object has properties of:
|
|
|
|
* info.type -- The short name of the service
|
|
* info.domain -- The domain for git protocol use
|
|
* info.user -- The name of the user/org on the git host
|
|
* info.project -- The name of the project on the git host
|
|
|
|
## Version Contract
|
|
|
|
The major version will be bumped any time…
|
|
|
|
* The constructor stops accepting URLs that it previously accepted.
|
|
* A method is removed.
|
|
* A method can no longer accept the number and type of arguments it previously accepted.
|
|
* A method can return a different type than it currently returns.
|
|
|
|
Implications:
|
|
|
|
* I do not consider the specific format of the urls returned from, say
|
|
`.https()` to be a part of the contract. The contract is that it will
|
|
return a string that can be used to fetch the repo via HTTPS. But what
|
|
that string looks like, specifically, can change.
|
|
* Dropping support for a hosted git provider would constitute a breaking
|
|
change.
|
|
|
|
## Usage
|
|
|
|
### const info = hostedGitInfo.fromUrl(gitSpecifier[, options])
|
|
|
|
* *gitSpecifer* is a URL of a git repository or a SCP-style specifier of one.
|
|
* *options* is an optional object. It can have the following properties:
|
|
* *noCommittish* — If true then committishes won't be included in generated URLs.
|
|
* *noGitPlus* — If true then `git+` won't be prefixed on URLs.
|
|
|
|
### const infoOrURL = hostedGitInfo.fromManifest(manifest[, options])
|
|
|
|
* *manifest* is a package manifest, such as that returned by [`pacote.manifest()`](https://npmjs.com/pacote)
|
|
* *options* is an optional object. It can have the same properties as `fromUrl` above.
|
|
|
|
## Methods
|
|
|
|
All of the methods take the same options as the `fromUrl` factory. Options
|
|
provided to a method override those provided to the constructor.
|
|
|
|
* info.file(path, opts)
|
|
|
|
Given the path of a file relative to the repository, returns a URL for
|
|
directly fetching it from the githost. If no committish was set then
|
|
`HEAD` will be used as the default.
|
|
|
|
For example `hostedGitInfo.fromUrl("git@github.com:npm/hosted-git-info.git#v1.0.0").file("package.json")`
|
|
would return `https://raw.githubusercontent.com/npm/hosted-git-info/v1.0.0/package.json`
|
|
|
|
* info.shortcut(opts)
|
|
|
|
eg, `github:npm/hosted-git-info`
|
|
|
|
* info.browse(path, fragment, opts)
|
|
|
|
eg, `https://github.com/npm/hosted-git-info/tree/v1.2.0`,
|
|
`https://github.com/npm/hosted-git-info/tree/v1.2.0/package.json`,
|
|
`https://github.com/npm/hosted-git-info/tree/v1.2.0/README.md#supported-hosts`
|
|
|
|
* info.bugs(opts)
|
|
|
|
eg, `https://github.com/npm/hosted-git-info/issues`
|
|
|
|
* info.docs(opts)
|
|
|
|
eg, `https://github.com/npm/hosted-git-info/tree/v1.2.0#readme`
|
|
|
|
* info.https(opts)
|
|
|
|
eg, `git+https://github.com/npm/hosted-git-info.git`
|
|
|
|
* info.sshurl(opts)
|
|
|
|
eg, `git+ssh://git@github.com/npm/hosted-git-info.git`
|
|
|
|
* info.ssh(opts)
|
|
|
|
eg, `git@github.com:npm/hosted-git-info.git`
|
|
|
|
* info.path(opts)
|
|
|
|
eg, `npm/hosted-git-info`
|
|
|
|
* info.tarball(opts)
|
|
|
|
eg, `https://github.com/npm/hosted-git-info/archive/v1.2.0.tar.gz`
|
|
|
|
* info.getDefaultRepresentation()
|
|
|
|
Returns the default output type. The default output type is based on the
|
|
string you passed in to be parsed
|
|
|
|
* info.toString(opts)
|
|
|
|
Uses the getDefaultRepresentation to call one of the other methods to get a URL for
|
|
this resource. As such `hostedGitInfo.fromUrl(url).toString()` will give
|
|
you a normalized version of the URL that still uses the same protocol.
|
|
|
|
Shortcuts will still be returned as shortcuts, but the special case github
|
|
form of `org/project` will be normalized to `github:org/project`.
|
|
|
|
SSH connect strings will be normalized into `git+ssh` URLs.
|
|
|
|
## Supported hosts
|
|
|
|
Currently this supports GitHub (including Gists), Bitbucket, GitLab and Sourcehut.
|
|
Pull requests for additional hosts welcome.
|