Code Monkey home page Code Monkey logo

minecloud's People

Contributors

314pies avatar aaronho-0716 avatar bglossner avatar krajla avatar yxliaoyx avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar

minecloud's Issues

[Task] Add custom prefix for each configuration package

Is your feature request related to a problem? Please describe.
Currently, every Discord BOT are having the same command prefix - mc.
Which will become messy easily when there's more than one game deployed in the Discord Server.

Describe the solution you'd like
In the configuration package for each game, each BOT should have their own prefix.

Describe alternatives you've considered
N/A

Additional context
Add any other context or screenshots about the feature request here.
N/A

[Feature request] Update a Route53 DNS record with the IP of the EC2 instance

Is your feature request related to a problem? Please describe.
Every time the Ec2 machine starts, a script could be run to update a configurable DNS record.

Describe the solution you'd like
I own a domain which I would like to use to make it easier to connect to the server by creating a record like minecraft.mydomain.cloud.

In the guide How to automatically update IP addresses a script is run at each boot to update a DNS record with the new IP address. The DNS name is added as a tag to the EC2 instance.
This could also be implemented as a Linux systemd service

An alternative solution would be to integrate the DNS update functionality into the Lambda function which posts the IP address into the Discord channel.

Whatever solution is implemented, the script could look at the EC2 instance tags and if there is a DNS_RECORD tag present it could execute the update Route53 dns record functionality. This would make this an optional feature, which can be controlled by giving an optional environment variable DNS_RECORD_TAG=minecraft.mydomain.cloud

[Optional?]Address cold start issue

Task Description

If the command hit the lambda endpoint and the lambda is still cold, it will result in time-out (because our lambda also need to call aws API to spin-up EC2...etc)
Right now how we solved it is by detecting whether the lambda is cold, and prompt user to try again if it's - probably no big deal at most of the time.

This issue should be solvable by utilizing a Discord API/feature that can offer response first and update it later.

[BUG] Backup-folders.txt paths doesn't support path with space

Describe the bug
When there's space it the line, each segment of the line will be considered as a individual path, causing the copying behavior failed

To Reproduce
Steps to reproduce the behavior:

  1. Go to '...'
  2. Click on '....'
  3. Scroll down to '....'
  4. See error

Expected behavior
A clear and concise description of what you expected to happen.

Screenshots
If applicable, add screenshots to help explain your problem.

Desktop (please complete the following information):

  • OS: [e.g. iOS]
  • Browser [e.g. chrome, safari]
  • Version [e.g. 22]

Smartphone (please complete the following information):

  • Device: [e.g. iPhone6]
  • OS: [e.g. iOS8.1]
  • Browser [e.g. stock browser, safari]
  • Version [e.g. 22]

Additional context
Add any other context about the problem here.

[Task] Delay server IP sending time

To-Fill

Please ping me on Discord directly if you're interested in working on this.

Is your feature request related to a problem? Please describe.
A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]

Describe the solution you'd like
A clear and concise description of what you want to happen.

Describe alternatives you've considered
A clear and concise description of any alternative solutions or features you've considered.

Additional context
Add any other context or screenshots about the feature request here.

Installation Trouble

I tried deploying with a brand new AWS account.

I do have multiple AWS account credentials on my laptop so I used the correct profile (passing the --profile) tag

Pre requisites

USER@xxx-MacBook-Pro MineCloud-1.1.0 % node --version
v18.4.0
USER@xxx-MacBook-Pro MineCloud-1.1.0 % aws --version
aws-cli/2.7.9 Python/3.9.13 Darwin/20.5.0 source/x86_64 prompt/off

Terminal Log

xxx@xxx-MacBook-Pro MineCloud-1.1.0 % npx cdk deploy --profile minecraft-discord
Bundling asset MineCloud/MineCloud_discord_commands_register_lambda/Code/Stage...

  cdk.out/bundling-temp-4e685f68940a765a4ed4847d4d773ddf7e2d7dfb3afa6065170b3443da43b77d/index.js  370.3kb

⚡ Done in 22ms
Bundling asset MineCloud/MineCloud_discord_interactions_endpoint_construct/MineCloud_discord_interactions_endpoint_lambda/Code/Stage...

  cdk.out/bundling-temp-6626f17e65c370d5c0f9f5f0aac55e2ce76f0fb27a8fa4ff20c2220cf3e6ca2c/index.js  18.7mb ⚠️

⚡ Done in 152ms
Bundling asset MineCloud/MineCloud_discord_interactions_endpoint_construct/MineCloud_discord_command_processor_lambda/Code/Stage...

  cdk.out/bundling-temp-a4eb7f2edfaee3b0511d1ca7be7999344e11db9698f37ce9f2759340055524ce/index.js  19.0mb ⚠️

⚡ Done in 199ms

✨  Synthesis time: 7.45s

MineCloud: building assets...

[0%] start: Building 97817db928c43d4646fed3437ff70ca3fe8d1ca5d5538e80726641d669c244fd:<AWS_ACC_ID>-ap-south-1
[0%] start: Building 0e22f72895a5bd555e2ce81d5dc6b7d01ac1835cd925dd80276ba2dad75c13fb:<AWS_ACC_ID>-ap-south-1
[0%] start: Building 903be65b9594a9f17d7120273620367e7830b6d087fc9591f31dc5a080049e46:<AWS_ACC_ID>-ap-south-1
[0%] start: Building 2b36d5d4dcb60993ddf36ecf68feed35ecbc70c3b92dcd77638a2c876866ad88:<AWS_ACC_ID>-ap-south-1
[0%] start: Building 85bb78ae8c7c9ad2d7d8a193f0ee234de6d82fdfba52da88120ea46ad54feea4:<AWS_ACC_ID>-ap-south-1
[0%] start: Building e30e6151fa91fad623f41b3e17ed2885697fde9fd59c95edbad26c7ec837a58a:<AWS_ACC_ID>-ap-south-1
[16%] success: Built 97817db928c43d4646fed3437ff70ca3fe8d1ca5d5538e80726641d669c244fd:<AWS_ACC_ID>-ap-south-1
[33%] success: Built 0e22f72895a5bd555e2ce81d5dc6b7d01ac1835cd925dd80276ba2dad75c13fb:<AWS_ACC_ID>-ap-south-1
[50%] success: Built 903be65b9594a9f17d7120273620367e7830b6d087fc9591f31dc5a080049e46:<AWS_ACC_ID>-ap-south-1
[66%] success: Built 2b36d5d4dcb60993ddf36ecf68feed35ecbc70c3b92dcd77638a2c876866ad88:<AWS_ACC_ID>-ap-south-1
[83%] success: Built 85bb78ae8c7c9ad2d7d8a193f0ee234de6d82fdfba52da88120ea46ad54feea4:<AWS_ACC_ID>-ap-south-1
[100%] success: Built e30e6151fa91fad623f41b3e17ed2885697fde9fd59c95edbad26c7ec837a58a:<AWS_ACC_ID>-ap-south-1

MineCloud: assets built

MineCloud: deploying... [1/1]
[0%] start: Publishing 97817db928c43d4646fed3437ff70ca3fe8d1ca5d5538e80726641d669c244fd:<AWS_ACC_ID>-ap-south-1
[0%] start: Publishing 0e22f72895a5bd555e2ce81d5dc6b7d01ac1835cd925dd80276ba2dad75c13fb:<AWS_ACC_ID>-ap-south-1
[0%] start: Publishing 903be65b9594a9f17d7120273620367e7830b6d087fc9591f31dc5a080049e46:<AWS_ACC_ID>-ap-south-1
[0%] start: Publishing 2b36d5d4dcb60993ddf36ecf68feed35ecbc70c3b92dcd77638a2c876866ad88:<AWS_ACC_ID>-ap-south-1
[0%] start: Publishing 85bb78ae8c7c9ad2d7d8a193f0ee234de6d82fdfba52da88120ea46ad54feea4:<AWS_ACC_ID>-ap-south-1
[0%] start: Publishing e30e6151fa91fad623f41b3e17ed2885697fde9fd59c95edbad26c7ec837a58a:<AWS_ACC_ID>-ap-south-1
[16%] success: Published 85bb78ae8c7c9ad2d7d8a193f0ee234de6d82fdfba52da88120ea46ad54feea4:<AWS_ACC_ID>-ap-south-1
[33%] success: Published 2b36d5d4dcb60993ddf36ecf68feed35ecbc70c3b92dcd77638a2c876866ad88:<AWS_ACC_ID>-ap-south-1
[50%] success: Published 97817db928c43d4646fed3437ff70ca3fe8d1ca5d5538e80726641d669c244fd:<AWS_ACC_ID>-ap-south-1
[66%] success: Published 0e22f72895a5bd555e2ce81d5dc6b7d01ac1835cd925dd80276ba2dad75c13fb:<AWS_ACC_ID>-ap-south-1
[83%] success: Published 903be65b9594a9f17d7120273620367e7830b6d087fc9591f31dc5a080049e46:<AWS_ACC_ID>-ap-south-1
[100%] success: Published e30e6151fa91fad623f41b3e17ed2885697fde9fd59c95edbad26c7ec837a58a:<AWS_ACC_ID>-ap-south-1
MineCloud: creating CloudFormation changeset...
4:08:05 PM | CREATE_FAILED        | AWS::CloudFormation::CustomResource | MineClouddiscordcommandsregisterresource
Received response status [FAILED] from custom resource. Message returned: Error: 2023-05-07T10:38:04.485Z c0c2fd89-6da0-4857-a322-43bba04d23b8 Task timed out after 3.01 seconds

Logs: /aws/lambda/MineCloud-MineClouddiscordcommandsregisterlambda95-n8pTPd6Hw3t2

at invokeUserFunction (/var/task/framework.js:2:6)
at processTicksAndRejections (internal/process/task_queues.js:95:5)
at async onEvent (/var/task/framework.js:1:369)
at async Runtime.handler (/var/task/cfn-response.js:1:1573) (RequestId: cad00625-ab3f-4c88-b864-ee8ec4fd5dc5)


 ❌  MineCloud failed: Error: The stack named MineCloud failed creation, it may need to be manually deleted from the AWS console: ROLLBACK_COMPLETE: Received response status [FAILED] from custom resource. Message returned: Error: 2023-05-07T10:38:04.485Z c0c2fd89-6da0-4857-a322-43bba04d23b8 Task timed out after 3.01 seconds

Logs: /aws/lambda/MineCloud-MineClouddiscordcommandsregisterlambda95-n8pTPd6Hw3t2

    at invokeUserFunction (/var/task/framework.js:2:6)
    at processTicksAndRejections (internal/process/task_queues.js:95:5)
    at async onEvent (/var/task/framework.js:1:369)
    at async Runtime.handler (/var/task/cfn-response.js:1:1573) (RequestId: cad00625-ab3f-4c88-b864-ee8ec4fd5dc5)
    at FullCloudFormationDeployment.monitorDeployment (/Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:380:10236)
    at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
    at async deployStack2 (/Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:383:145458)
    at async /Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:383:128776
    at async run (/Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:383:126782)

 ❌ Deployment failed: Error: Stack Deployments Failed: Error: The stack named MineCloud failed creation, it may need to be manually deleted from the AWS console: ROLLBACK_COMPLETE: Received response status [FAILED] from custom resource. Message returned: Error: 2023-05-07T10:38:04.485Z c0c2fd89-6da0-4857-a322-43bba04d23b8 Task timed out after 3.01 seconds

Logs: /aws/lambda/MineCloud-MineClouddiscordcommandsregisterlambda95-n8pTPd6Hw3t2

    at invokeUserFunction (/var/task/framework.js:2:6)
    at processTicksAndRejections (internal/process/task_queues.js:95:5)
    at async onEvent (/var/task/framework.js:1:369)
    at async Runtime.handler (/var/task/cfn-response.js:1:1573) (RequestId: cad00625-ab3f-4c88-b864-ee8ec4fd5dc5)
    at deployStacks (/Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:383:129083)
    at process.processTicksAndRejections (node:internal/process/task_queues:95:5)
    at async CdkToolkit.deploy (/Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:383:147507)
    at async exec4 (/Users/USER/Downloads/MineCloud-1.1.0/node_modules/aws-cdk/lib/index.js:438:51799)

Stack Deployments Failed: Error: The stack named MineCloud failed creation, it may need to be manually deleted from the AWS console: ROLLBACK_COMPLETE: Received response status [FAILED] from custom resource. Message returned: Error: 2023-05-07T10:38:04.485Z c0c2fd89-6da0-4857-a322-43bba04d23b8 Task timed out after 3.01 seconds

Logs: /aws/lambda/MineCloud-MineClouddiscordcommandsregisterlambda95-n8pTPd6Hw3t2

    at invokeUserFunction (/var/task/framework.js:2:6)
    at processTicksAndRejections (internal/process/task_queues.js:95:5)
    at async onEvent (/var/task/framework.js:1:369)
    at async Runtime.handler (/var/task/cfn-response.js:1:1573) (RequestId: cad00625-ab3f-4c88-b864-ee8ec4fd5dc5)
$ % 

AWS CloudFormation

Timestamp Logical ID Status Status reason
2023-05-07 16:08:06 UTC+0530 MineCloud ROLLBACK_IN_PROGRESS The following resource(s) failed to create [MineClouddiscordcommandsregisterresource, MineCloudec2instanceInstanceProfile7C956219]. Rollback requested by user.
2023-05-07 16:08:06 UTC+0530 MineCloudec2instanceInstanceProfile7C956219 CREATE_FAILED Resource creation cancelled
2023-05-07 16:08:05 UTC+0530 MineClouddiscordcommandsregisterresource CREATE_FAILED Received response status [FAILED] from custom resource. Message returned: Error: 2023-05-07T10:38:04.485Z c0c2fd89-6da0-4857-a322-43bba04d23b8 Task timed out after 3.01 seconds Logs: /aws/lambda/MineCloud-MineClouddiscordcommandsregisterlambda95-n8pTPd6Hw3t2 at invokeUserFunction (/var/task/framework.js:2:6) at processTicksAndRejections (internal/process/task_queues.js:95:5) at async onEvent (/var/task/framework.js:1:369) at async Runtime.handler (/var/task/cfn-response.js:1:1573) (RequestId: cad00625-ab3f-4c88-b864-ee8ec4fd5dc5)

[Planning] Plan out backup mechanism details

Task Description

Figured out the details about how the backup mechanism should work.
Some possible options are:

  • S3
  • Git (we use GitHub as our backup mechanism before... but we probably don't want to encourage people doing this)

[Feature request] Make it easy to add server config files to the automated setup

Is your feature request related to a problem? Please describe.
Setting up a Minecraft server often requires some properties to be set in multiple files.
For example my kids like to play with "allow-cheats=true" and I want the whitelisting to be enabled on the server so that I know that only my kids an d their friends can access it.

Describe the solution you'd like
I do not have a good solution yet, but I would like to kickoff a discussion about this.
I could imagine that there is a folder where the following files (in the case of a minecraft server) can be put into:

  • whitelist.json
  • ops.json
  • server.properties

The issue is that I do not want those files to be committed accidentally with all my kids UUIDs and usernames in there. So I could imagine again an approach where we put dummy files in there and one would need to copy them, remove a suffix like "template" and then they will be recognized during server-init and copied to the new machine.

5. Auto shutdown the server when no one is online

Task description

Write CDK code to configure server auto shutdown script.

Please refer to our existing script for checking user connection:
https://gist.github.com/314pies/ac0aa3aa4e42e83363b6ca1a6c426564
This script will auto check for TCP and SSH connection and shut down the server if no connection is found

Note:

  • Because every multi-player game have their own connecting protocol (probably either TCP or UDP). We will want to make this part modular enough (and probably open a public interface in the future) so that this solution can be more generic for other multiplayer server hosting.
  • @yxliaoyx Have came up an solution/script for detecting UDP connection for his Project Zomboid server

Test

Make sure the server shutdown when no one is online.

Document

Update Readme if needed.

Configure Log outputs / Add instruction about where and how we can finds Log

Task description

When something went wrong with our script/service, we want a persistence place to see for logs.
Research and configure the EC2 instance so that we have a centralize folder to look for our logs.
Or at least offer a clear instruction to where we can find the logs.

Test

Make sure the logs exist in the target folder/make sure the instruction is clear and accurate

Document

Update Readme if needed.

4.5 Setup discord messaging script

Task description

  • Setup discord messaging script so that this can be used for later features (ex: send IP to channel, notfity server update...etc)
  • Do it via CDK

Notes:

Test

Deploy to your dev stack and confirm the message showed up in the Discord channel when running the script.

Document
N/A

11. Send message to Discord channel when the server start/stop

Task description

Test

Deploy to your dev stack and confirm the message showed up in the Discord channel.

Document
N/A

[Task][Planning] Convert to an Integrated Repository with NX

To reduce our reliance on Discord for operational tasks, we have decided to introduce a web page that allows authorized users to manage game servers. Therefore, we need to implement a Web Application, and we have chosen React.js + Next.js as the development options to ensure scalability and flexibility for future development.

As a result, in this mission, we will outline the prerequisites for this change and use NX to convert the project into a monorepo.

Monorepo Conversion using NX:

  • Use NX to convert the project into a monorepo, allowing for efficient management of multiple related packages and components.

[Task][Planning]Setup CI/CD

  • Add a tool to automate configuration package testing
    • The tool should be able to automatically deploy the config packs and validate the game server is spun up correctly.
  • Plan out the implementation details

[BUG] [Backup Download] InvalidRequestThe authorization mechanism you have provided is not supported. Please use AWS4-HMAC-SHA256.[...]

Hi! Thanks for the project, it seems interesting.

I just installed MineCloud and it went well. I started it, connected to it, played for a few minutes and then started a backup.

Then I tried to ask for the download link. I'm unfamiliar with S3, so I wont paste the whole answer here in case it contains sensitive information, but it was a long-ass link. When I clicked on it, I got the following error:

InvalidRequestThe authorization mechanism you have provided is not supported. Please use AWS4-HMAC-SHA256.[...]

(the [...] is again a chain of character I'm not putting here, don't know if it's security sensitive)

I googled the error, it seems to be a problem with my region, which is eu-west-3. Looks like US regions support an older authorization mechanism that is not supported in Europe: Stack Overlow exemple

Again thanks a lot ;)

4. Configure Minecraft server as a Linux service in EC2 instance, via CDK

Task description

Research and write CDK code that are able to configure Minecraft server as a system service after the EC2 instance start.

Note:

Test

Make sure the you are able to connect to Minecraft server after the instance start

Document

Update Readme if needed.

[Task] Update Readme

This reddit comment point it out S3 free tier is only for first 12 months.
We should update the readme to make this clear.

It's also a good idea to add a section for creating a budget for AWS accounts.

[Question] How can the spot instance request issue be resolved?

I'm playing around with cdk deploy and cdk destroy to test the DNS name feature I requested in #68

The "cdk destroy" operation takes ages until it finally fails. I'm not 100% sure yet, but it seems as if the spot instance requests issue, you described somewhere in the comments, led to the issue that a second VM has been created, which does not get deleted by the cdk destroy operation and an attempt to delete the whole stack fails because the ENI is still in use by the second spot instance that is running.

aws ec2 describe-spot-instance-requests --query "SpotInstanceRequests[].SpotInstanceRequestId"

The question is whether there is a way to avoid a second VM to be started, becoming somehow detached from the CDK/CFN state?

[Task] Switch EC2 machine image to Ubuntu 22.04 LTS

Task Description

Right now, we are using Amazon Linux 2 as our main EC2 image.
However:

  1. Some games require more modern libraries (ex: Minecraft Bedrock server requires GLIBC_2.27)
  2. LinuxGSM (Linux Game Server Managers) has better support to Ubuntu
  3. It's (probably) easier to install SteamCMD on Ubuntu with apt package manager support

Thus, the main goals for this task are

Here are some useful resources that can be helpful:

Testing

  • Deploy and ensure all the features still work
  • Deploy to make sure the Ubuntu image at least works with the following regions:
    • US West
    • EU
    • Asia East

[Abandoned] Parameterize SSH ingress rule

Why

I found it easier to connect to (and debug) the EC2 instances from the AWS console Session Manager.
image

How

I'd like to not have an open SSH port in that case. Maybe we could add a flag "EC2_SSH_ENABLED" to determine if the port should be open or not.

[Task] Add support to specify backup folders

Task description

Right now, our built-in backup feature only backup the /opt/minecloud/server folder. However, since some games might have different files locations, it will be essential to provide support to backup other folders as well.

Note:

  • This is the server backup script
  • While passing in folder list to the script, pay attention to the EoL(End on Line) character issue between Linux and Windows.

Test

Make sure the feature is working with manual testing.

Document

Update Readme/Wiki if needed.

[Feature request] List of access required for a IAM user

Is your feature request related to a problem? Please describe.
Sort of - it's a non issue, really. I don't exactly know what permissions the access key needs.

Describe the solution you'd like
I'd like in the FAQ for there to be a list of accesses it needs.

Describe alternatives you've considered
I ended up just giving it admin access, which usually isn't a good practice.

Additional context
I'm using this on a IAM user to minimize the amount of root keys I give out.

Thank you for your work on the project - it's quite amazing!

[Feature request] Support Satisfactory

Is your feature request related to a problem? Please describe.
Satisfactory supports dedicated servers, but is not supported by MineCloud

Describe the solution you'd like
Add support for Satisfactory.

Describe alternatives you've considered
Completely separate package to run that game, but there should be a lot of shared code with this package. So would make sense just to add it on.

Additional context
Game Website: https://www.satisfactorygame.com/
I would like to work on this feature personally

3. Write CDK code to spin-up an EC2 SPOT instance

Task description

Write CDK code for creating a new EC2 instance stack. The CDK stack should at least support the following:

  • server's region
  • instance type
  • Spot instance
  • (Nice to have) Custom IP inbound-outbound policy.

Test

Make sure the stack deployed succeed.

Document

Update Readme if needed.

9. Setup Discord BOT commands during EC2 initialization

Task Description

We want to setup Discord BOT command when spinning up the stack (this only need to be done once)

This is the tutorial (https://discordjs.guide/creating-your-bot/command-deployment.html#guild-commands) for setting it up with a Node project.

Since it's a Node project, it's likely that we can convert it to a lambda and just treat is as a Custom resource.

(Or use the official API instead https://discord.com/developers/docs/interactions/application-commands#registering-a-command)

Test

  • If decided to do it with a lambda, you can utilize the lambda testing function during development.
  • Manually deploy it to confirm it works

Domumentation

N/A

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.