Skip to content

Latest commit

 

History

History
318 lines (218 loc) · 8.75 KB

Week_03.md

File metadata and controls

318 lines (218 loc) · 8.75 KB

Week 3: Back End (lol)

1. Achievements

Understand & Use the Benefits of TypeScript

I encouraged the developers working with specific APIs to specify what types of data they wanted to be given and what they would be sending back. Tanya needed two string inputs.

    export interface openaiQuery { eventDescription: string, musicGenre: string };

I was extracting those input strings from the user's input, but was also capturing a date that wouldn't be sent to openAI

    export interface userInput extends openaiQuery { date: Date };

Tanya would return two new strings & some numerical values corresponding to Spotify's recommendations engine

    export interface openaiResponse { mood: string, genre: string };

    export interface spotifyFeatures {
        valence: number, 
        energy: number,
        danceability: number,
        acousticness: number,
        tempo: number
    }

I would then send the recommendation scores to Gaj, along with the original captured date

    export interface spotifyQuery extends openaiResponse {
        date: Date,
        spotifyFeatures: spotifyFeatures
    };

Designing Server Architecture

I wanted to create a structure that was appropriate to the small size of our project, but also could accomodate changes & additions easily. This meant it was easy to adapt to Tanya's sudden discovery of embeddings on Thursday morning.

    // ./src/app.ts

    const app = express();
    const router = express.Router();
    app.use(routes);
    // ./src/routes/routes.ts

    import { router as openAI } from "./openAI/index.js";
    import { router as spotify } from "./spotify/index.js";
    app.use(openAI);
    app.use(spotify);
    export { router };
    // ./src/routes/openai/index.ts

    // import functions from corresponding file in ./src/controllers/
    app.get("/openAI", async (req: Request, res: Response) => {
        const input = await userInput();
        const output = await parseMood(input.eventDescription);
        return output;
    });

Planning & Communicating the Structure of a Server

I used mermaid.js syntax to quickly knock up a visual explainer of what our data was doing when a team member was finding it difficult to know which inputs & outputs they had to accomodate.

    graph TD

    input["Store User Input"]
    
    subgraph app["Our Server"]
        subgraph jason["Server Routes"]
            inSEvent["Event Description"]
            inSGenre["Genre Description"]
            inDDate["Date Object"]
            appApp["Combine Date & OpenAI response"]
            appOut["Select Parameters for Output"]
        end

        subgraph tanya["OpenAI Controller"]
            toOpenAI["Send Inputs"]
            fromOpenAI["Create Object from Response"]
        end
        
        subgraph gaj["Spotify Controller"]
            toSpotify["Send Inputs"]
            fromSpotify["Create Object from Response"]
        end
    end
    
    openai["OpenAI API"]
    spotify["Spotify API"]

    output["Playlist Output"]

    input --> inSEvent & inSGenre & inDDate
    inSEvent & inSGenre --> toOpenAI
    toOpenAI --> openai
    openai --> fromOpenAI
    inDDate & fromOpenAI --> appApp
    appApp --> toSpotify
    toSpotify --> spotify
    spotify --> fromSpotify
    fromSpotify --> appOut
    appOut --> output
Loading

Dev Scripts & Nodemon

Setting this...

    // ./nodemon.json
    {
        "watch": ["src"],
        "ext": "ts",
        "exec": "ts-node --esm -r tsconfig-paths/register ./src/app.ts"
    }

...and this...

    // ./package.json
    "scripts": {
        "compile": "npx tsc",
        "server": "node dist/app.js",
        "dev": "nodemon"
    }

...means this...

    npm run dev

...will run this...

    nodemon ts-node --esm -r tsconfig-paths/register ./src/app.ts

...for the whole team without them needing to learn the flags.


PromptSync is Awesome

Take terminal input from the user with literally one line of code? Yeah, thankyou.

    npm install promp-sync
    async function userInput(): userInput {
        const prompt = promptSync();

        const q1: string = prompt(`What happened on that date? How did you feel about it?`);
        const q2: string = prompt(`What genres of music do you like?`);

        const userInput: userInput = {
            eventDescription: q1,
            musicGenre: q2,
            date: new Date()
        };
        userInput.date.setFullYear(await prompt(`Type a 4 digit year`))
        userInput.date.setMonth(await prompt(`Type a 2 digit month`));
        userInput.date.setDate(await prompt(`Type a 2 digit day`));

        return userInput;
    }

Terminal Input


Project Management

I wanted to make sure we took advantage of Jira's capabilities without overwhelming anyone. One approach was to create custom views so that team members could hide irrelevant tasks.

Group by Person, Unfiltered


As the "done" column mounted, I also created a custom filter to hide completed tasks

Filter Menu

Filter Rules

Group by Person, Filtered


For stand-ups, I created an alternate view so we could see our progress across areas.

Group by Epics


I also created a custom "Blocked" status alongside the standard "To Do", "In Progress" & "Done", hidden by default. Then I used the Jira workflow designer to automatically block a task if it had an unresolved dependency and unblock it when ready

Workflow Designer


2. Difficulties

Toggle List
  • Responding to difficulties being experienced by another developer when my primary role was to communicate with their code.
  • Understanding the implications of apparently minor configuration choices on server architecture
  • Helping other developers to communicate about the project clearly; there was a fair amount of "what do I do with it when it goes into it", and I wasn't as effective at helping people clear up their question as I would like to be.

3. Full Progress List

Toggle Key
  • I feel like I've learned/demonstrated this skill in the past week
  • I have acquired some skill but need to develop further
  • I am not yet comfortable in this skill

Toggle List

TypeScript & Express

  • Develop a server using Express and TypeScript for backend applications (K9, S1, S11, S12)
  • Identify the server’s role within a full stack application (K1, K2, K3)
  • Understand the benefits of using TypeScript over JavaScript, such as improved code quality, enhanced developer productivity, and better tooling support (K7, S1)
  • Learn the basic syntax and features of TypeScript (S1, S16)

RESTFUL APIs

  • Grasp the concept and purpose of RESTful APIs (K11, S12)
  • Construct and implement RESTful APIs effectively (S1, S11, S12, S16)
  • Determine appropriate scenarios for applying RESTful APIs (K7, S9, B2)
  • Design endpoint structures for data creation, modification, and deletion (K11, S8, S12)
  • Utilize Postman to test RESTful APIs independently of frontend components, ensuring proper functionality, error handling, and adherence to API specifications (S5, S6, S7)
  • Gain experience in documenting the application’s architecture, API endpoints, and user guides for future reference and maintenance (S15, B4, B7, B8)
  • Practice creating JSON endpoints and using these endpoints to fetch and display data dynamically.
  • Dynamically update web page content without needing to reload the page.

Additional

  • Utilize node:fs for filesystem operations (S1, S16)
  • Gain experience in using developer tooling, including IDEs, linters, and formatters, to enhance productivity (B3, B9)

4. Feedback

Name Alex
What Went Well Perfect PL
Even Better If I wont change a comma