(bez virsraksta)

Maijs. 3., 2024 | 11:51 am

Link | ir doma | Add to Memories


(bez virsraksta)

Apr. 3., 2024 | 03:12 pm

http://klab.lv/allpics.bml?user=siddharta

Ko nozīmē "geho"? Ko šis lietotājs gribēja ar to teikt?

Link | ir doma | Add to Memories


LCF.user.js

Sep. 12., 2023 | 12:56 pm

// ==UserScript==
// @name LCF
// @namespace https://gist.github.com/mindbound
// @version 0.5.3
// @description Applies user-defined filters to the latest posts page
// @author mindbound
// @license WTFPL; http://www.wtfpl.net/
// @match http://klab.lv/stats/latest.bml
// @icon 
// @connect https://raw.githubusercontent.com
// @connect https://cdn.jsdelivr.net
// @require https://raw.githubusercontent.com/mindbound/GM_config/master/gm_config.js
// @require https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@latest/dist/tf.min.js
// @grant GM_xmlhttpRequest
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_registerMenuCommand
// @run-at document-end
// ==/UserScript==

"use strict";

let model;
let isTFBackendInitialized = false;

const MODEL_NAME = "LCF";
const MODEL_URL = "https://raw.githubusercontent.com/mindbound/LCF/master/model/model.json";
const MODEL_VERSION_URL = "https://raw.githubusercontent.com/mindbound/LCF/master/model/model_version.txt"
const MODEL_PROD = true;

const chars = "abcdefghijklmnopqrstuvwxyz0123456789_";
const charToInt = {};

for (let i = 0; i < chars.length; i++) {
charToInt[chars[i]] = i + 1;
}

const cfg = new GM_configStruct({
id: "LCFConfig",
title: `


LCF ${GM_info.script.version}


`,
events: {
open: function () {
makeDraggable(LCFConfig, LCFConfig_header);
LCFConfig_header.style.cursor = "move";
},
save: function () {
applyFilters();
}
},
fields: {
filterList: {
section: ["Filter List", "A list of user accounts to filter"],
type: "textarea",
default: "",
save: true
},
filterNew: {
label: "Filter all new users",
section: ["Options", "Additional filters and settings"],
type: "checkbox",
default: false,
save: true
},
filterImages: {
label: "Filter all images",
type: "checkbox",
default: false,
save: true
},
filterWithML: {
label: "ML-assisted filter",
type: "checkbox",
default: false,
save: true
}
},
frame: document.body.appendChild(document.createElement("div")),
css: `
#LCFConfig {
font-size: 13px;
background-color: #f3f6f4;
position: relative;
width: 350px;
margin: 0 auto;
}
#LCFConfig textarea {
font-family: monospace;
margin-left: auto;
margin-right: auto;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
width: 100%;
height: 325px;
resize: none;
font-size: 12px;
}
#LCFConfig_header p.lcftitle {
font-size: 20px;
font-weight: bold;
margin-bottom: 20px;
user-select: none;
padding: 0px;
}
#LCFConfig .config_var {
position: relative;
}
#LCFConfig .field_label {
width: 100%;
padding-right: 30px;
box-sizing: border-box;
user-select: none;
}
#LCFConfig .field_label label {
font-size: 14px;
}
#LCFConfig .section_header {
font-size: 18px;
font-weight: bold;
user-select: none;
}
#LCFConfig .section_desc {
font-size: 14px;
font-style: italic;
user-select: none;
}
#LCFConfig input[type="checkbox"] {
position: absolute;
right: 250px;
top: 50%;
transform: translateY(-70%);
}
#LCFConfig .saveclose_buttons {
font-size: 14px;
padding: 5px 10px;
}
#LCFConfig .reset {
user-select: none;
}
`
});

function makeDraggable(element, handle) {
if (!element) {
return;
}

let mdX = 0, mdY = 0, mdeX = 0, mdeY = 0;

const onMouseMove = (evt) => {
element.style.left = `${mdeX + evt.clientX - mdX}px`;
element.style.top = `${mdeY + evt.clientY - mdY}px`;
};

const onMouseUp = () => {
document.removeEventListener("mousemove", onMouseMove);
document.removeEventListener("mouseup", onMouseUp);
};

(handle ?? element).addEventListener("mousedown", function (evt) {
evt.preventDefault();
this.style.userSelect = "none";
mdX = evt.clientX;
mdY = evt.clientY;
mdeX = element.offsetLeft;
mdeY = element.offsetTop;

document.addEventListener("mousemove", onMouseMove);
document.addEventListener("mouseup", onMouseUp);
});
}

function usernameToSequence(username, maxLength) {
let sequence = [];

for (let char of username) {
if (charToInt[char]) {
sequence.push(charToInt[char]);
}
}

return sequence.concat(Array(maxLength - sequence.length).fill(0));
}

async function fetchRemoteModelVersion() {
try {
const response = await fetch(MODEL_VERSION_URL);

if (!response.ok) {
throw new Error(`Failed to fetch model version: ${response.statusText}`);
}

const version = await response.text();

return version.trim();
} catch (error) {
console.error(`Error fetching remote model version: ${error}`);

return null;
}
}

async function initializeTFBackend() {
if (typeof tf === "undefined") {
console.error("TensorFlow.js is not loaded");

return;
}

if (MODEL_PROD) {
await tf.enableProdMode();
} else {
await tf.enableDebugMode();
}

const isWebGLAvailable = await tf.setBackend("webgl");

if (isWebGLAvailable) {
await tf.ready();

return;
}

console.warn("Failed to set the WebGL backend for TensorFlow.js");

const isWASMAvailable = await tf.setBackend("wasm");

if (isWASMAvailable) {
await tf.ready();

return;
}

console.warn("Failed to set the WASM backend for TensorFlow.js");

const isCPUAvailable = await tf.setBackend("cpu");

if (isCPUAvailable) {
await tf.ready();

return;
}

console.warn("Failed to set the CPU backend for TensorFlow.js");
console.error("No suitable backend available");
}

function applyFilterList(fl) {
if (fl.length === 0) {
return;
}

const regexPatterns = fl.map(s => new RegExp(`\\b${s.replace("*", ".*")}\\b`));
const rows = Array.from(document.querySelectorAll("tr[valign='top']"));
const rowsToRemove = [];

for (let tr of rows) {
const href = tr?.querySelector("td:nth-child(2) span.ljuser a")?.getAttribute("href") ?? "";

for (let pattern of regexPatterns) {
if (pattern.test(href)) {
rowsToRemove.push(tr);
break;
}
}
}

for (let row of rowsToRemove) {
row.parentNode?.removeChild(row);
}
}

function applySpamFilter() {
let filterList = cfg.get("filterList");

if (typeof filterList !== "string") {
console.error("Unexpected filter list format");

return;
}

filterList = filterList.split("\n").map(e => e.trim()).filter(e => e.length > 0);
applyFilterList(filterList);
}

function applyNewUsersFilter() {
fetch("http://klab.lv/stats.bml")
.then((res) => {
if (!res.ok) {
throw new Error(`Bad network response: ${res.statusText}`);
}

return res.text();
})
.then((data) => {
try {
const dom = new DOMParser().parseFromString(data, "text/html");
const filterList = Array.from(
dom.querySelectorAll("ul:nth-of-type(5) a")
).map((a) => {
const match = /([^\/]+)\/$/.exec(a.getAttribute("href"));

if (!match) {
throw new Error("Unexpected URL format");
}

return match[1];
});

applyFilterList(filterList);
} catch (parseError) {
console.error(`Error while parsing or processing the data: ${parseError}`);
}
})
.catch((fetchError) => {
console.error(`Error in fetch operation: ${fetchError}`);
});
}

function applyImagesFilter() {
const images = document.querySelectorAll("img");

if (images.length === 0) {
return;
}

const imagesToHide = [];

images.forEach((img) => {
imagesToHide.push(img);
});

imagesToHide.forEach((img) => {
img.style.display = "none";
});
}

async function applyMLFilter() {
try {
if (!isTFBackendInitialized) {
await initializeTFBackend();
isTFBackendInitialized = true;
}

const localVersion = localStorage.getItem("modelVersion");
const remoteVersion = await fetchRemoteModelVersion();

if (!localStorage[`tensorflowjs_models/${MODEL_NAME}/model_topology`] || (remoteVersion && (!localVersion || remoteVersion > localVersion))) {
model = await tf.loadLayersModel(MODEL_URL);
await model.save(`localstorage://${MODEL_NAME}`);
localStorage.setItem("modelVersion", remoteVersion);
} else if (!model) {
model = await tf.loadLayersModel(`localstorage://${MODEL_NAME}`);
}

const response = await fetch("http://klab.lv/stats/latest.bml");

if (!response.ok) {
throw new Error(`Bad network response: ${response.statusText}`);
}

const data = await response.text();
const maxLength = 16;
const regex = /.*?(.*?)<\/b><\/a><\/span>/g;
const usernames = [];
let match;

while ((match = regex.exec(data)) !== null) {
usernames.push(match[1]);
}

const usernameSequences = usernames.map(username => usernameToSequence(username, maxLength));

tf.tidy(() => {
const inputTensor = tf.tensor(usernameSequences);
const outputTensor = model.predict(inputTensor);
outputTensor.data().then(predictions => {
const filterList = usernames.filter((username, idx) => predictions[idx] > 0.5);
applyFilterList(filterList);
});
});
} catch (error) {
console.error(`Error in ML filter: ${error}`);
}
}

function applyFilters() {
applySpamFilter();
cfg.get("filterNew") && applyNewUsersFilter();
cfg.get("filterImages") && applyImagesFilter();
cfg.get("filterWithML") && applyMLFilter();
}

function openConfig() {
cfg.open();
LCFConfig.style = `
height: 75%;
max-height: 620px;
top: calc(50% - 350px);
width: 400px;
left: calc(50% - 150px);
border: 1px solid #000000;
border-radius: 5px;
margin: 0px;
opacity: 1.0;
overflow: auto;
padding: 10px;
position: fixed;
z-index: 65536;
display: block;
right: auto;
bottom: auto;
`;
}

(function () {
GM_registerMenuCommand("Settings", openConfig);
applyFilters();
})();

Link | ir doma | Add to Memories


(bez virsraksta)

Sep. 12., 2023 | 12:54 pm

eu, kas notiek ar cibu? :(

Link | ir doma | Add to Memories


(bez virsraksta)

Nov. 18., 2022 | 07:24 pm

OK es izlasīju visu par to Mastodon, bet neko nesapratu. kā man viņu lietot

Link | ir doma {1} | Add to Memories


(bez virsraksta)

Aug. 21., 2022 | 01:51 am

eu, bet tas grieztais siers nav nemaz tik slikts!

Link | ir doma | Add to Memories


(bez virsraksta)

Aug. 15., 2022 | 10:55 pm

to jau vairāk nevar izturēt! nu viss, man arī vajag lielo cibas filtru. pastāstiet kāds man, stulbenim, kā to uzlikt. :) es lejuplādēju to failu, mēģināju atvērt ar firefox. tad skatījos latests, bet viss pa vecam. nu kā?

Link | ir doma {4} | Add to Memories


(bez virsraksta)

Dec. 7., 2021 | 01:12 am

// ==UserScript==
// @name LCF
// @namespace https://gist.github.com/mindbound
// @version 0.3.5
// @description Filters out idiots and spammers in the latest posts page
// @author mindbound
// @license WTFPL; http://www.wtfpl.net/
// @match http://klab.lv/stats/latest.bml
// @icon 
// @require https://raw.githubusercontent.com/sizzlemctwizzle/GM_config/master/gm_config.js
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_registerMenuCommand
// @run-at document-end
// ==/UserScript==

"use strict";

const cfg = new GM_configStruct({
id: "LCFConfig",
title: `


LCF


`,
events: {
open: function () {
makeDraggable(LCFConfig, LCFConfig_header);
LCFConfig_header.style.cursor = "move";
},
save: function () {
apply();
}
},
fields: {
filterList: {
section: ["Filter List", "Create a list of user accounts to filter"],
type: "textarea",
default: "",
save: true
}
},
frame: document.body.appendChild(document.createElement("div")),
css: `
#LCFConfig {
background-color: #f3f6f4;
}
#LCFConfig textarea {
margin-left: auto;
margin-right: auto;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
width: 100%;
height: 325px;
resize: none;
font-size: 12px;
}
#LCFConfig_header p.lcftitle {
font-size: 20px;
font-weight: bold;
margin-bottom: 20px;
}
`
});

function makeDraggable(element, handle) {
if (!element) {
return;
}

let mdX = 0, mdY = 0, mdeX = 0, mdeY = 0;

(handle ?? element).onmousedown = function (event) {
this.style.userSelect = "none";
mdX = event.clientX;
mdY = event.clientY;
mdeX = element.offsetLeft;
mdeY = element.offsetTop;
onmouseup = () => {
onmousemove = null;
this.style.userSelect = "";
};
onmousemove = (evt) => {
element.style.left = `${mdeX + evt.clientX - mdX}px`;
element.style.top = `${mdeY + evt.clientY - mdY}px`;
};
};
}

function apply() {
const filterList = cfg.get("filterList").split("\n").filter((e) => e.length > 0);

if (filterList.length !== 0) {
for (let tr of document.querySelectorAll("tr[valign='top']")) {
if (filterList.some(
(s) => tr
.querySelectorAll("td")[1]
.querySelector("span.ljuser")
.getElementsByTagName("a")[0]
.getAttribute("href")
.includes(s)
)) {
tr.parentNode.removeChild(tr);
}
}
}
}

function openConfig() {
cfg.open();
LCFConfig.style = `
height: 75%;
max-height: 500px;
top: calc(50% - 200px);
width: 300px;
left: calc(50% - 150px);
border: 1px solid #000000;
border-radius: 5px;
margin: 0px;
opacity: 1.0;
overflow: auto;
padding: 10px;
position: fixed;
z-index: 65536;
display: block;
right: auto;
bottom: auto;
`;
}

(function () {
GM_registerMenuCommand("Settings", openConfig);
apply();
})();

Link | ir doma {6} | Add to Memories


(bez virsraksta)

Dec. 7., 2021 | 01:06 am

Nu labi, tagad tas tomēr būs jādara. Kā man uzlikt to Lielo Cibas Filtru. Es skatijos to mindbond pamācību, nokopēju to kodu, bet kur man viņš jāliek? Cibā lietotāja informācijā?

Link | ir doma {3} | Add to Memories


(bez virsraksta)

Dec. 11., 2020 | 04:44 pm

Pirmo reizi par tādu Kimu Kiduku dzirdu. Ar ko gan viņš tik slavens?

Link | ir doma {1} | Add to Memories


(bez virsraksta)

Jun. 14., 2007 | 02:37 pm

Es aizgāju uz to torrentspy.com. Bet kā tur tās filmas var skatīties?

Link | ir doma {2} | Add to Memories


(bez virsraksta)

Jun. 14., 2007 | 02:36 pm

Eu, a kā ielikt Cibā bildi?

Link | ir doma | Add to Memories


D

Jun. 2., 2007 | 02:55 pm

Es esmu mudaks.

Link | ir doma | Add to Memories