All files program.ts

100% Statements 50/50
100% Branches 0/0
100% Functions 9/9
100% Lines 42/42

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166          20x                                                                                 20x             20x 1x             1x 1x 1x         1x                 20x 2x 2x 2x   2x                 20x 2x 2x 2x   2x             20x 1x 1x 2x                 20x 3x 3x 3x   3x                 20x       2x 2x 4x               20x 1x 1x 1x   1x                 20x 1x 1x 1x   1x   20x  
/**
 * Services for the program table.
 * @packageDocumentation
 */
 
import { BaseService } from "./util";
 
/**
 * Program architecture.
 */
export interface Program {
  id: number;
  name: string;
}
 
/**
 * Program with only ID architecture.
 */
interface ProgramID {
  id: number;
}
 
/**
 * Program with only name architecture.
 */
interface ProgramName {
  name: string;
}
 
/**
 * Program count architecture.
 */
interface ProgramCount {
  count: number;
}
 
/**
 * Program with last insert ID architecture.
 */
interface ProgramInsertID {
  id: number;
}
 
/**
 * Program services.
 */
export class ProgramService extends BaseService {
  /**
   * Create a new program.
   *
   * @param name The new program's name.
   * @returns The new program's ID.
   */
  public async createProgram(name: string): Promise<number> {
    const sql1 = `
      INSERT INTO Program (
        name
      ) VALUES (
        ?
      );
    `;
    const sql2 = `SELECT LAST_INSERT_ID() AS id;`;
    const params1 = [name];
    const rows: ProgramInsertID[][] = await this.dbm.db.executeMany(
      [sql1, sql2],
      [params1, []]
    );
 
    return rows[1][0].id;
  }
 
  /**
   * Check if a program exists.
   *
   * @param programID A program's ID.
   * @returns Whether or not the program exists.
   */
  public async programExists(programID: number): Promise<boolean> {
    const sql = `SELECT id FROM Program WHERE id = ?;`;
    const params = [programID];
    const rows: ProgramID[] = await this.dbm.execute(sql, params);
 
    return rows.length > 0;
  }
 
  /**
   * Get a program.
   *
   * @param programID A program's ID.
   * @returns The program.
   */
  public async getProgram(programID: number): Promise<Program> {
    const sql = `SELECT * FROM Program WHERE id = ?;`;
    const params = [programID];
    const rows: Program[] = await this.dbm.execute(sql, params);
 
    return rows[0];
  }
 
  /**
   * Delete a program.
   * @param programID A program's ID.
   */
  public async deleteProgram(programID: number): Promise<void> {
    const sql = `DELETE FROM Program WHERE id = ?;`;
    const params = [programID];
    await this.dbm.execute(sql, params);
  }
 
  /**
   * Get a program's name.
   *
   * @param programID A program's ID.
   * @returns The program's name.
   */
  public async getProgramName(programID: number): Promise<string> {
    const sql = `SELECT name FROM Program WHERE id = ?;`;
    const params = [programID];
    const rows: ProgramName[] = await this.dbm.execute(sql, params);
 
    return rows[0].name;
  }
 
  /**
   * Set a program's name.
   *
   * @param programID A program's ID.
   * @param newName The program's new name.
   */
  public async setProgramName(
    programID: number,
    newName: string
  ): Promise<void> {
    const sql = `UPDATE Program SET name = ? WHERE id = ?;`;
    const params = [newName, programID];
    await this.dbm.execute(sql, params);
  }
 
  /**
   * Get all programs.
   *
   * @returns All programs.
   */
  public async getPrograms(): Promise<Program[]> {
    const sql = `SELECT * FROM Program ORDER BY id;`;
    const params = [];
    const rows: Program[] = await this.dbm.execute(sql, params);
 
    return rows;
  }
 
  /**
   * Get the number of posts associated with a program.
   *
   * @param programID A program's ID.
   * @returns The number of linked posts.
   */
  public async numLinkedPosts(programID: number): Promise<number> {
    const sql = `SELECT COUNT(*) AS count FROM Post WHERE programID = ?;`;
    const params = [programID];
    const rows: ProgramCount[] = await this.dbm.execute(sql, params);
 
    return rows[0].count;
  }
}