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