Compare commits
15 Commits
v0.1.0
...
dependabot
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7f686e227f | ||
|
a2e3cd60ed
|
|||
| aa870623ff | |||
|
|
5937f8c918 | ||
| b9031579d6 | |||
| cccd31016e | |||
| 6d09eeaf99 | |||
| caa05f26f6 | |||
|
7ef5b154ea
|
|||
|
75260016c8
|
|||
|
93ed637537
|
|||
|
19d8a93f3f
|
|||
|
d000c7b0ee
|
|||
|
6fd42bea39
|
|||
|
7d70129495
|
17
CHANGELOG.md
17
CHANGELOG.md
@@ -4,14 +4,25 @@ All notable changes to this project will be documented in this file.
|
||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||
|
||||
## [0.0.3] - 2021-12-07
|
||||
## [v0.2.0] - 2021-12-10
|
||||
### Fixed
|
||||
-Fix async work with repository state
|
||||
## [v0.1.1] - 2021-12-09
|
||||
### Added
|
||||
- icon
|
||||
## [v0.1.0] - 2021-12-07
|
||||
### Added
|
||||
- Overwrite button in error message
|
||||
|
||||
## [v0.0.3] - 2021-12-07
|
||||
### Fixed
|
||||
- Small fixes
|
||||
## [0.0.2] - 2021-12-06
|
||||
|
||||
## [v0.0.2] - 2021-12-06
|
||||
### Added
|
||||
- README 😂
|
||||
### Changed
|
||||
- Rename `user` => `name` in settings options
|
||||
|
||||
## [0.0.1] - 2021-12-06
|
||||
## [v0.0.1] - 2021-12-06
|
||||
- Initial release
|
||||
BIN
media/folder-green-git-icon.png
Normal file
BIN
media/folder-green-git-icon.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.7 KiB |
1240
package-lock.json
generated
1240
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -2,7 +2,7 @@
|
||||
"name": "gitcheck",
|
||||
"displayName": "Git User Check",
|
||||
"description": "Checking the user's compliance with the repository",
|
||||
"version": "0.1.0",
|
||||
"version": "0.2.2",
|
||||
"preview": false,
|
||||
"engines": {
|
||||
"vscode": "^1.62.0"
|
||||
@@ -19,6 +19,7 @@
|
||||
"type": "git",
|
||||
"url": "https://github.com/maksim77/gitcheck.git"
|
||||
},
|
||||
"icon": "media/folder-green-git-icon.png",
|
||||
"activationEvents": [
|
||||
"workspaceContains:.git/"
|
||||
],
|
||||
|
||||
@@ -1,21 +1,41 @@
|
||||
import * as vscode from 'vscode';
|
||||
import { GitExtension } from './git';
|
||||
import { GitExtension, Repository } from './git';
|
||||
|
||||
class UserConf {
|
||||
domain: string = "";
|
||||
name: string = "";
|
||||
email:string = "";
|
||||
|
||||
valid: boolean = false;
|
||||
|
||||
constructor() {
|
||||
var conf = vscode.workspace.getConfiguration("gitcheck");
|
||||
const _domain = conf.get<string>("domain");
|
||||
const _name = conf.get<string>("name");
|
||||
const _email = conf.get<string>("email");
|
||||
if (!(_domain && _name && _email)) {
|
||||
console.log("Missing config params");
|
||||
this.valid = false;
|
||||
} else {
|
||||
this.domain = _domain;
|
||||
this.name = _name;
|
||||
this.email = _email;
|
||||
this.valid = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export async function activate() {
|
||||
var conf = vscode.workspace.getConfiguration("gitcheck");
|
||||
const domain = conf.get<string>("domain");
|
||||
const name = conf.get<string>("name");
|
||||
const email = conf.get<string>("email");
|
||||
const userConf = new UserConf();
|
||||
if (!userConf.valid) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!vscode.workspace.workspaceFolders) {
|
||||
console.log("No opened workspace");
|
||||
return;
|
||||
}
|
||||
|
||||
if (!(domain && name && email)) {
|
||||
console.log("Missing config params");
|
||||
return;
|
||||
}
|
||||
|
||||
const gitExt = vscode.extensions.getExtension<GitExtension>('vscode.git')!;
|
||||
const git = gitExt.exports.getAPI(1);
|
||||
@@ -25,16 +45,29 @@ export async function activate() {
|
||||
}
|
||||
|
||||
const repository = await git.openRepository(vscode.workspace.workspaceFolders[0].uri);
|
||||
|
||||
if (!repository) {
|
||||
console.error("Cannot open git repository");
|
||||
return;
|
||||
}
|
||||
|
||||
repository.state.remotes.forEach(async remote => {
|
||||
let remotesLen:number = 0;
|
||||
repository.state.onDidChange(() => {
|
||||
if (remotesLen > 0) {
|
||||
return;
|
||||
}
|
||||
remotesLen = repository.state.remotes.length;
|
||||
|
||||
if (remotesLen > 0) {
|
||||
gitCheck(repository, userConf);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function gitCheck(repo:Repository, conf:UserConf) {
|
||||
repo.state.remotes.forEach(async remote => {
|
||||
const pushUrl = remote.pushUrl;
|
||||
if (pushUrl && pushUrl.includes(domain)) {
|
||||
var gitConfig = await repository.getConfigs();
|
||||
if (pushUrl && pushUrl.includes(conf.domain)) {
|
||||
var gitConfig = await repo.getConfigs();
|
||||
var gitName:string = "";
|
||||
var gitEmail:string = "";
|
||||
gitConfig = gitConfig.filter( elem => {
|
||||
@@ -44,8 +77,8 @@ export async function activate() {
|
||||
console.error("Missing user creds in git");
|
||||
const option = await vscode.window.showErrorMessage("Missing user settings in git", "Overwrite");
|
||||
if (option && option === "Overwrite") {
|
||||
await repository.setConfig("user.name", name);
|
||||
await repository.setConfig("user.email", email);
|
||||
await repo.setConfig("user.name", conf.name);
|
||||
await repo.setConfig("user.email", conf.email);
|
||||
}
|
||||
return;
|
||||
}
|
||||
@@ -63,12 +96,12 @@ export async function activate() {
|
||||
break;
|
||||
}
|
||||
});
|
||||
if (gitName !== name || gitEmail !== email) {
|
||||
if (gitName !== conf.name || gitEmail !== conf.email) {
|
||||
console.error("Wrong user settings in git");
|
||||
const option = await vscode.window.showErrorMessage("Wrong user settings in git", "Overwrite");
|
||||
if (option && option === "Overwrite") {
|
||||
await repository.setConfig("user.name", name);
|
||||
await repository.setConfig("user.email", email);
|
||||
await repo.setConfig("user.name", conf.name);
|
||||
await repo.setConfig("user.email", conf.email);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user