From 5f21a263e0c7b2b823a54e51837de9e095b02c64 Mon Sep 17 00:00:00 2001 From: Harminder virk Date: Thu, 16 May 2019 11:05:34 +0530 Subject: [PATCH] feat: initiate project --- .circleci/config.yml | 40 +++++++++++++ .editorconfig | 22 +++++++ .github/COMMIT_CONVENTION.md | 70 ++++++++++++++++++++++ .github/ISSUE_TEMPLATE/bug_report.md | 29 +++++++++ .github/ISSUE_TEMPLATE/feature_request.md | 28 +++++++++ .github/PULL_REQUEST_TEMPLATE.md | 28 +++++++++ .gitignore | 14 +++++ .npmrc | 1 + CONTRIBUTING.md | 48 +++++++++++++++ LICENSE.md | 9 +++ README.md | 39 ++++++++++++ config.json | 9 +++ japaFile.js | 6 ++ package.json | 72 +++++++++++++++++++++++ tsconfig.json | 3 + tslint.json | 6 ++ typedoc.js | 1 + 17 files changed, 425 insertions(+) create mode 100644 .circleci/config.yml create mode 100644 .editorconfig create mode 100644 .github/COMMIT_CONVENTION.md create mode 100644 .github/ISSUE_TEMPLATE/bug_report.md create mode 100644 .github/ISSUE_TEMPLATE/feature_request.md create mode 100644 .github/PULL_REQUEST_TEMPLATE.md create mode 100644 .gitignore create mode 100644 .npmrc create mode 100644 CONTRIBUTING.md create mode 100644 LICENSE.md create mode 100644 README.md create mode 100644 config.json create mode 100644 japaFile.js create mode 100644 package.json create mode 100644 tsconfig.json create mode 100644 tslint.json create mode 100644 typedoc.js diff --git a/.circleci/config.yml b/.circleci/config.yml new file mode 100644 index 0000000..1b5ff3c --- /dev/null +++ b/.circleci/config.yml @@ -0,0 +1,40 @@ +version: 2 +jobs: + build_10.15.3: + docker: + - image: 'circleci/node:10.15.3' + working_directory: ~/app + steps: + - checkout + - restore_cache: + keys: + - 'v1-dependencies-{{ checksum "package.json" }}' + - v1-dependencies- + - run: npm install + - save_cache: + paths: + - node_modules + key: 'v1-dependencies-{{ checksum "package.json" }}' + - run: npm test + build_latest: + docker: + - image: 'circleci/node:latest' + working_directory: ~/app + steps: + - checkout + - restore_cache: + keys: + - 'v1-dependencies-{{ checksum "package.json" }}' + - v1-dependencies- + - run: npm install + - save_cache: + paths: + - node_modules + key: 'v1-dependencies-{{ checksum "package.json" }}' + - run: npm test +workflows: + version: 2 + workflow: + jobs: + - build_10.15.3 + - build_latest diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..62c428f --- /dev/null +++ b/.editorconfig @@ -0,0 +1,22 @@ +# http://editorconfig.org + +[*] +indent_style = space +indent_size = 2 +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true + +[*.json] +insert_final_newline = ignore + +[**.min.js] +indent_style = ignore +insert_final_newline = ignore + +[MakeFile] +indent_style = tab + +[*.md] +trim_trailing_whitespace = false diff --git a/.github/COMMIT_CONVENTION.md b/.github/COMMIT_CONVENTION.md new file mode 100644 index 0000000..33a78e6 --- /dev/null +++ b/.github/COMMIT_CONVENTION.md @@ -0,0 +1,70 @@ +## Git Commit Message Convention + +> This is adapted from [Angular's commit convention](https://github.com/conventional-changelog/conventional-changelog/tree/master/packages/conventional-changelog-angular). + +Using conventional commit messages, we can automate the process of generating the CHANGELOG file. All commits messages will automatically be validated against the following regex. + +``` js +/^(revert: )?(feat|fix|docs|style|refactor|perf|test|workflow|ci|chore|types|build)((.+))?: .{1,50}/ +``` + +## Commit Message Format +A commit message consists of a **header**, **body** and **footer**. The header has a **type**, **scope** and **subject**: + +> The **scope** is optional + +``` +feat(router): add support for prefix + +Prefix makes it easier to append a path to a group of routes +``` + +1. `feat` is type. +2. `router` is scope and is optional +3. `add support for prefix` is the subject +4. The **body** is followed by a blank line. +5. The optional **footer** can be added after the body, followed by a blank line. + +## Types +Only one type can be used at a time and only following types are allowed. + +- feat +- fix +- docs +- style +- refactor +- perf +- test +- workflow +- ci +- chore +- types +- build + +If a type is `feat`, `fix` or `perf`, then the commit will appear in the CHANGELOG.md file. However if there is any BREAKING CHANGE, the commit will always appear in the changelog. + +### Revert +If the commit reverts a previous commit, it should begin with `revert:`, followed by the header of the reverted commit. In the body it should say: `This reverts commit `., where the hash is the SHA of the commit being reverted. + +## Scope +The scope could be anything specifying place of the commit change. For example: `router`, `view`, `querybuilder`, `database`, `model` and so on. + +## Subject +The subject contains succinct description of the change: + +- use the imperative, present tense: "change" not "changed" nor "changes". +- don't capitalize first letter +- no dot (.) at the end + +## Body + +Just as in the **subject**, use the imperative, present tense: "change" not "changed" nor "changes". +The body should include the motivation for the change and contrast this with previous behavior. + +## Footer + +The footer should contain any information about **Breaking Changes** and is also the place to +reference GitHub issues that this commit **Closes**. + +**Breaking Changes** should start with the word `BREAKING CHANGE:` with a space or two newlines. The rest of the commit message is then used for this. + diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md new file mode 100644 index 0000000..4bcd407 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -0,0 +1,29 @@ +--- +name: Bug report +about: Report identified bugs +--- + + + +## Prerequisites + +We do our best to reply to all the issues on time. If you will follow the given guidelines, the turn around time will be faster. + +- Lots of raised issues are directly not bugs but instead are design decisions taken by us. +- Make use of our [forum](https://forum.adonisjs.com/), or [discord server](https://discord.me/adonisjs), if you are not sure that you are reporting a bug. +- Ensure the issue isn't already reported. +- Ensure you are reporting the bug in the correct repo. + +*Delete the above section and the instructions in the sections below before submitting* + +## Package version + + +## Node.js and npm version + + +## Sample Code (to reproduce the issue) + + +## BONUS (a sample repo to reproduce the issue) + diff --git a/.github/ISSUE_TEMPLATE/feature_request.md b/.github/ISSUE_TEMPLATE/feature_request.md new file mode 100644 index 0000000..abd44a5 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/feature_request.md @@ -0,0 +1,28 @@ +--- +name: Feature request +about: Propose changes for adding a new feature +--- + + + +## Prerequisites + +We do our best to reply to all the issues on time. If you will follow the given guidelines, the turn around time will be faster. + +## Consider an RFC + +Please create an [RFC](https://github.com/adonisjs/rfcs) instead, if + +- Feature introduces a breaking change +- Demands lots of time and changes in the current code base. + +*Delete the above section and the instructions in the sections below before submitting* + +## Why this feature is required (specific use-cases will be appreciated)? + + +## Have you tried any other work arounds? + + +## Are you willing to work on it with little guidance? + diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md new file mode 100644 index 0000000..03b50fa --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -0,0 +1,28 @@ + + +## Proposed changes + +Describe the big picture of your changes here to communicate to the maintainers why we should accept this pull request. If it fixes a bug or resolves a feature request, be sure to link to that issue. + +## Types of changes + +What types of changes does your code introduce? + +_Put an `x` in the boxes that apply_ + +- [ ] Bugfix (non-breaking change which fixes an issue) +- [ ] New feature (non-breaking change which adds functionality) +- [ ] Breaking change (fix or feature that would cause existing functionality to not work as expected) + +## Checklist + +_Put an `x` in the boxes that apply. You can also fill these out after creating the PR. If you're unsure about any of them, don't hesitate to ask. We're here to help! This is simply a reminder of what we are going to look for before merging your code._ + +- [ ] I have read the [CONTRIBUTING](https://github.com/poppinss/logger/blob/master/CONTRIBUTING.md) doc +- [ ] Lint and unit tests pass locally with my changes +- [ ] I have added tests that prove my fix is effective or that my feature works. +- [ ] I have added necessary documentation (if appropriate) + +## Further comments + +If this is a relatively large or complex change, kick off the discussion by explaining why you chose the solution you did and what alternatives you considered, etc... diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..966cd35 --- /dev/null +++ b/.gitignore @@ -0,0 +1,14 @@ +node_modules +coverage +.DS_STORE +.nyc_output +.idea +.vscode/ +*.sublime-project +*.sublime-workspace +*.log +build +dist +yarn.lock +shrinkwrap.yaml +package-lock.json diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000..a54c771 --- /dev/null +++ b/.npmrc @@ -0,0 +1 @@ +message="chore(release): %s" diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 0000000..992acdb --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,48 @@ +# Contributing + +AdonisJs is a community driven project. You are free to contribute in any of the following ways. + +- [Coding style](coding-style) +- [Fix bugs by creating PR's](fix-bugs-by-creating-prs) +- [Share an RFC for new features or big changes](share-an-rfc-for-new-features-or-big-changes) +- [Report security issues](report-security-issues) +- [Be a part of the community](be-a-part-of-community) + +## Coding style + +Majority of AdonisJs core packages are written in Typescript. Having a brief knowledge of Typescript is required to contribute to the core. [Learn more](https://adonisjs.com/coding-style) about the same. + +## Fix bugs by creating PR's + +We appreciate every time you report a bug in the framework or related libraries. However, taking time to submit a PR can help us in fixing bugs quickly and ensure a healthy and stable eco-system. + +Go through the following points, before creating a new PR. + +1. Create an issue discussing the bug or short-coming in the framework. +2. Once approved, go ahead and fork the REPO. +3. Make sure to start from the `develop`, since this is the upto date branch. +4. Make sure to keep commits small and relevant. +5. We follow [conventional-commits](https://github.com/conventional-changelog/conventional-changelog) to structure our commit messages. Instead of running `git commit`, you must run `npm commit`, which will show you prompts to create a valid commit message. +6. Once done with all the changes, create a PR against the `develop` branch. + +## Share an RFC for new features or big changes + +Sharing PR's for small changes works great. However, when contributing big features to the framework, it is required to go through the RFC process. + +### What is an RFC? + +RFC stands for **Request for Commits**, a standard process followed by many other frameworks including [Ember](https://github.com/emberjs/rfcs), [yarn](https://github.com/yarnpkg/rfcs) and [rust](https://github.com/rust-lang/rfcs). + +In brief, RFC process allows you to talk about the changes with everyone in the community and get a view of the core team before dedicating your time to work on the feature. + +The RFC proposals are created as issues on [adonisjs/rfcs](https://github.com/adonisjs/rfcs) repo. Make sure to read the README to learn about the process in depth. + +## Report security issues + +All of the security issues, must be reported via [email](mailto:virk@adonisjs.com) and not using any of the public channels. [Learn more](https://adonisjs.com/security) about the security policy + +## Be a part of community + +We welcome you to participate in the [forum](https://forum.adonisjs.com/) and the AdonisJs [discord server](https://discord.me/adonisjs). You are free to ask your questions and share your work or contributions made to AdonisJs eco-system. + +We follow a strict [Code of Conduct](https://adonisjs.com/community-guidelines) to make sure everyone is respectful to each other. diff --git a/LICENSE.md b/LICENSE.md new file mode 100644 index 0000000..5160223 --- /dev/null +++ b/LICENSE.md @@ -0,0 +1,9 @@ +# The MIT License + +Copyright 2019 Harminder virk, contributors + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..b4a1909 --- /dev/null +++ b/README.md @@ -0,0 +1,39 @@ + + +## Table of contents + +- [@poppinss/logger](#poppinsslogger) + - [Change log](#change-log) + - [Contributing](#contributing) + - [Authors & License](#authors--license) + + + +# @poppinss/logger + +[![circleci-image]][circleci-url] +[![npm-image]][npm-url] +![](https://img.shields.io/badge/Typescript-294E80.svg?style=for-the-badge&logo=typescript) + +## Change log + +The change log can be found in the [CHANGELOG.md](CHANGELOG.md) file. + +## Contributing + +Everyone is welcome to contribute. Please go through the following guides, before getting started. + +1. [Contributing](https://adonisjs.com/contributing) +2. [Code of conduct](https://adonisjs.com/code-of-conduct) + + +## Authors & License +[Harminder virk](https://github.com/Harminder virk) and [contributors](https://github.com/poppinss/logger/graphs/contributors). + +MIT License, see the included [MIT](LICENSE.md) file. + +[circleci-image]: https://img.shields.io/circleci/project/github/poppinss/logger/master.svg?style=for-the-badge&logo=circleci +[circleci-url]: https://circleci.com/gh/poppinss/logger "circleci" + +[npm-image]: https://img.shields.io/npm/v/@poppinss/logger.svg?style=for-the-badge&logo=npm +[npm-url]: https://npmjs.org/package/@poppinss/logger "npm" diff --git a/config.json b/config.json new file mode 100644 index 0000000..cda7b1c --- /dev/null +++ b/config.json @@ -0,0 +1,9 @@ +{ + "core": true, + "ts": true, + "license": "MIT", + "services": [ + "circleci" + ], + "minNodeVersion": "10.15.3" +} \ No newline at end of file diff --git a/japaFile.js b/japaFile.js new file mode 100644 index 0000000..46b457c --- /dev/null +++ b/japaFile.js @@ -0,0 +1,6 @@ +require('ts-node/register') + +const { configure } = require('japa') +configure({ + files: ['test/**/*.spec.ts'] +}) diff --git a/package.json b/package.json new file mode 100644 index 0000000..0053a49 --- /dev/null +++ b/package.json @@ -0,0 +1,72 @@ +{ + "name": "@poppinss/logger", + "version": "0.0.0", + "description": "Logger built on top of pino to be used by AdonisJs", + "scripts": { + "mrm": "mrm --preset=@adonisjs/mrm-preset", + "pretest": "npm run lint", + "test": "node japaFile.js", + "lint": "tslint --project tsconfig.json", + "clean": "del build", + "compile": "npm run lint && npm run clean && tsc", + "build": "npm run compile && typedoc --excludePrivate && git add docs", + "commit": "git-cz", + "release": "np", + "version": "npm run build" + }, + "keywords": [ + "logger", + "logging", + "pino", + "adonisjs" + ], + "author": "virk,poppinss", + "license": "MIT", + "devDependencies": { + "@adonisjs/mrm-preset": "^2.0.2", + "@types/node": "^12.0.2", + "commitizen": "^3.1.1", + "cz-conventional-changelog": "^2.1.0", + "del-cli": "^1.1.0", + "doctoc": "^1.4.0", + "husky": "^2.3.0", + "japa": "^2.0.10", + "mrm": "^1.2.1", + "np": "^5.0.1", + "ts-node": "^8.1.0", + "tslint": "^5.16.0", + "tslint-eslint-rules": "^5.4.0", + "typedoc": "^0.14.2", + "typedoc-plugin-external-module-name": "^2.1.0", + "typescript": "^3.4.5" + }, + "nyc": { + "exclude": [ + "test" + ], + "extension": [ + ".ts" + ] + }, + "main": "build/index.js", + "files": [ + "build/src", + "build/index.d.ts", + "build/index.js" + ], + "husky": { + "hooks": { + "pre-commit": "doctoc README.md --title='## Table of contents' && git add README.md", + "commit-msg": "node ./node_modules/@adonisjs/mrm-preset/validateCommit/conventional/validate.js" + } + }, + "config": { + "commitizen": { + "path": "cz-conventional-changelog" + } + }, + "np": { + "contents": ".", + "anyBranch": false + } +} diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..ff4e273 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,3 @@ +{ + "extends": "./node_modules/@adonisjs/mrm-preset/_tsconfig" +} diff --git a/tslint.json b/tslint.json new file mode 100644 index 0000000..5f51f2a --- /dev/null +++ b/tslint.json @@ -0,0 +1,6 @@ +{ + "extends": [ + "@adonisjs/mrm-preset/_tslint" + ], + "rules": {} +} diff --git a/typedoc.js b/typedoc.js new file mode 100644 index 0000000..879b8d7 --- /dev/null +++ b/typedoc.js @@ -0,0 +1 @@ +module.exports = require('@adonisjs/mrm-preset/_typedoc.js')()