Change to use env variable
This commit is contained in:
parent
87b4be35ea
commit
f85cd149db
45
lib/ldap.ts
45
lib/ldap.ts
|
@ -1,45 +0,0 @@
|
||||||
import { Client } from "ldapts";
|
|
||||||
|
|
||||||
export interface Member {
|
|
||||||
name: string;
|
|
||||||
id: string;
|
|
||||||
program: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export async function getMembers(
|
|
||||||
year: string,
|
|
||||||
term: string
|
|
||||||
): Promise<Member[]> {
|
|
||||||
if (term !== "winter" && term !== "spring" && term !== "fall") {
|
|
||||||
throw new Error(`[getMembers] Not a valid term: "${term}"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
let members: Member[] = [];
|
|
||||||
|
|
||||||
const url = "ldap://ldap1.csclub.uwaterloo.ca";
|
|
||||||
const searchDN = "ou=People,dc=csclub,dc=uwaterloo,dc=ca";
|
|
||||||
const client = new Client({
|
|
||||||
url,
|
|
||||||
});
|
|
||||||
try {
|
|
||||||
await client.bind("", "");
|
|
||||||
const { searchEntries } = await client.search(searchDN, {
|
|
||||||
scope: "sub",
|
|
||||||
filter: `(&(objectClass=member)(term=${term.slice(0, 1)}${year}))`,
|
|
||||||
});
|
|
||||||
|
|
||||||
members = searchEntries
|
|
||||||
.map((item) => {
|
|
||||||
return {
|
|
||||||
name: item.cn as string,
|
|
||||||
id: item.uid as string,
|
|
||||||
program: item.program === undefined ? "" : (item.program as string),
|
|
||||||
};
|
|
||||||
})
|
|
||||||
.sort((item1: Member, item2: Member) => item1.id.localeCompare(item2.id));
|
|
||||||
} finally {
|
|
||||||
await client.unbind();
|
|
||||||
}
|
|
||||||
|
|
||||||
return members;
|
|
||||||
}
|
|
|
@ -0,0 +1,65 @@
|
||||||
|
import { Client } from "ldapts";
|
||||||
|
|
||||||
|
export interface Member {
|
||||||
|
name: string;
|
||||||
|
id: string;
|
||||||
|
program: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function getMembers(
|
||||||
|
year: string,
|
||||||
|
term: string
|
||||||
|
): Promise<Member[]> {
|
||||||
|
if (term !== "winter" && term !== "spring" && term !== "fall") {
|
||||||
|
throw new Error(`[getMembers] Not a valid term: "${term}"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
let members: Member[] = [];
|
||||||
|
if (
|
||||||
|
process.env.USE_LDAP !== undefined &&
|
||||||
|
["true", "1", "y", "yes"].includes(process.env.USE_LDAP.toLowerCase())
|
||||||
|
) {
|
||||||
|
const url = "ldap://ldap1.csclub.uwaterloo.ca";
|
||||||
|
const searchDN = "ou=People,dc=csclub,dc=uwaterloo,dc=ca";
|
||||||
|
const client = new Client({
|
||||||
|
url,
|
||||||
|
});
|
||||||
|
try {
|
||||||
|
await client.bind("", "");
|
||||||
|
const { searchEntries } = await client.search(searchDN, {
|
||||||
|
scope: "sub",
|
||||||
|
filter: `(&(objectClass=member)(term=${term.slice(0, 1)}${year}))`,
|
||||||
|
});
|
||||||
|
|
||||||
|
members = searchEntries
|
||||||
|
.map((item) => {
|
||||||
|
return {
|
||||||
|
name: item.cn as string,
|
||||||
|
id: item.uid as string,
|
||||||
|
program: item.program === undefined ? "" : (item.program as string),
|
||||||
|
};
|
||||||
|
})
|
||||||
|
.sort((item1: Member, item2: Member) =>
|
||||||
|
item1.id.localeCompare(item2.id)
|
||||||
|
);
|
||||||
|
} finally {
|
||||||
|
await client.unbind();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
members = [
|
||||||
|
{
|
||||||
|
name: "John Smith",
|
||||||
|
id: "j12smith",
|
||||||
|
program: "MAT/Mathematics Computer Science",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Jane Smith",
|
||||||
|
id: "j34smith",
|
||||||
|
program: "MAT/Mathematics Computer Science",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
return members;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(getMembers("2021", "winter"));
|
|
@ -1,8 +0,0 @@
|
||||||
import { getMembers } from "./ldap";
|
|
||||||
|
|
||||||
const main = async () => {
|
|
||||||
const members = await getMembers("2020", "winter");
|
|
||||||
console.log(members);
|
|
||||||
};
|
|
||||||
|
|
||||||
void main();
|
|
Loading…
Reference in New Issue