Merge pull request #585 from HeyPuter/eric/rename-traits-to-features

refactor(backend): rename traits to features
This commit is contained in:
Nariman Jelveh 2024-07-11 14:37:12 -07:00 committed by GitHub
commit b790bab9c0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
26 changed files with 79 additions and 79 deletions

View File

@ -17,7 +17,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { AsyncProviderTrait } = require("../../traits/AsyncProviderTrait");
const { AsyncProviderFeature } = require("../../traits/AsyncProviderFeature");
const { HLMkdir, QuickMkdir } = require("../hl_operations/hl_mkdir");
const { Context } = require("../../util/context");
const { HLWrite } = require("../hl_operations/hl_write");
@ -32,8 +32,8 @@ const { HLRemove } = require("../hl_operations/hl_remove");
class BatchCommand extends AdvancedBase {
static TRAITS = [
new AsyncProviderTrait(),
static FEATURES = [
new AsyncProviderFeature(),
]
static async run (executor, parameters) {
const instance = new this();

View File

@ -26,8 +26,8 @@ const StringParam = require('../../api/filesystem/StringParam');
const FlagParam = require("../../api/filesystem/FlagParam");
const UserParam = require('../../api/filesystem/UserParam');
const FSNodeContext = require('../FSNodeContext');
const { ContextAwareTrait } = require('../../traits/ContextAwareTrait');
const { OtelTrait } = require('../../traits/OtelTrait');
const { ContextAwareFeature } = require('../../traits/ContextAwareFeature');
const { OtelFeature } = require('../../traits/OtelFeature');
const { HLFilesystemOperation } = require('./definitions');
const { is_valid_path } = require('../validation');
const { HLRemove } = require('./hl_remove');
@ -249,8 +249,8 @@ class HLMkdir extends HLFilesystemOperation {
parent_directories_created: () => [],
}
static TRAITS = [
new OtelTrait([
static FEATURES = [
new OtelFeature([
'_get_existing_parent',
'_create_parents',
]),

View File

@ -33,7 +33,7 @@ const { HLFilesystemOperation } = require("./definitions");
const { MkTree } = require("./hl_mkdir");
const { Actor } = require("../../services/auth/Actor");
class WriteCommonTrait {
class WriteCommonFeature {
install_in_instance (instance) {
instance._verify_size = async function () {
if (
@ -84,8 +84,8 @@ class HLWrite extends HLFilesystemOperation {
- create shortcuts
`
static TRAITS = [
new WriteCommonTrait(),
static FEATURES = [
new WriteCommonFeature(),
]
static PARAMETERS = {

View File

@ -21,7 +21,7 @@ const { id2path } = require("../../helpers");
const { PuterPath } = require("../lib/PuterPath");
const { NodeUIDSelector } = require("../node/selectors");
const { OtelTrait } = require("../../traits/OtelTrait");
const { OtelFeature } = require("../../traits/OtelFeature");
const { Context } = require("../../util/context");
const { DB_WRITE } = require("../../services/database/consts");
@ -195,8 +195,8 @@ class DatabaseFSEntryService extends AdvancedBase {
static STATUS_READY = {};
static STATUS_RUNNING_JOB = {};
static TRAITS = [
new OtelTrait([
static FEATURES = [
new OtelFeature([
'insert',
'update',
'delete',

View File

@ -17,13 +17,13 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { WeakConstructorTrait } = require("../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../traits/WeakConstructorFeature");
const { Eq, And } = require("./query/query");
const { Entity } = require("./entitystorage/Entity");
class IdentifierUtil extends AdvancedBase {
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
async detect_identifier (object) {

View File

@ -18,7 +18,7 @@
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { instance_ } = require("../../monitor/PerformanceMonitor");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
const { Property } = require("./Property");
const { Entity } = require("../entitystorage/Entity");
const FSNodeContext = require("../../filesystem/FSNodeContext");
@ -29,13 +29,13 @@ const FSNodeContext = require("../../filesystem/FSNodeContext");
* Both wrapping and registering are done by RegistrantService.
*/
class Mapping extends AdvancedBase {
static TRAITS = [
static FEATURES = [
// Whenever you can override something, it's reasonable to want
// to pull the desired implementation from somewhere else to
// avoid repeating yourself. Class constructors are one of a few
// examples where this is typically not possible.
// However, javascript is magic, and we do what we want.
new WeakConstructorTrait(),
new WeakConstructorFeature(),
]
static create (context, data) {

View File

@ -17,11 +17,11 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
class PropType extends AdvancedBase {
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
static create (context, data, k) {

View File

@ -17,11 +17,11 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
class Property extends AdvancedBase {
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
static create (context, name, descriptor) {

View File

@ -17,15 +17,15 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
const { Context } = require("../../util/context");
/**
* BaseES is a base class for Entity Store classes.
*/
class BaseES extends AdvancedBase {
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
// Default implementations

View File

@ -17,11 +17,11 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
class Entity extends AdvancedBase {
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
constructor (args) {

View File

@ -21,14 +21,14 @@ const { BaseES } = require("./BaseES");
const APIError = require("../../api/APIError");
const { Entity } = require("./Entity");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
const { And, Or, Eq, Like, Null, Predicate, PredicateUtil, IsNotNull } = require("../query/query");
const { DB_WRITE } = require("../../services/database/consts");
class RawCondition extends AdvancedBase {
// properties: sql:string, values:any[]
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
}

View File

@ -17,11 +17,11 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { WeakConstructorTrait } = require("../../traits/WeakConstructorTrait");
const { WeakConstructorFeature } = require("../../traits/WeakConstructorFeature");
class Predicate extends AdvancedBase {
static TRAITS = [
new WeakConstructorTrait(),
static FEATURES = [
new WeakConstructorFeature(),
]
}

View File

@ -40,7 +40,7 @@ class EntityStoreService extends BaseService {
});
}
// TODO: can replace these with MethodProxyTrait
// TODO: can replace these with MethodProxyFeature
async create (entity) {
return await this.upstream.upsert(entity, { old_entity: null });
}

View File

@ -18,10 +18,10 @@
*/
const { AdvancedBase } = require("@heyputer/puter-js-common");
const { Context } = require("../util/context");
const { ContextAwareTrait } = require("../traits/ContextAwareTrait");
const { OtelTrait } = require("../traits/OtelTrait");
const { ContextAwareFeature } = require("../traits/ContextAwareFeature");
const { OtelFeature } = require("../traits/OtelFeature");
const APIError = require("../api/APIError");
const { AssignableMethodsTrait } = require("../traits/AssignableMethodsTrait");
const { AssignableMethodsFeature } = require("../traits/AssignableMethodsFeature");
const CONTEXT_KEY = Context.make_context_key('operation-trace');
@ -220,10 +220,10 @@ class OperationTraceService {
}
class BaseOperation extends AdvancedBase {
static TRAITS = [
new ContextAwareTrait(),
new OtelTrait(['run']),
new AssignableMethodsTrait(),
static FEATURES = [
new ContextAwareFeature(),
new OtelFeature(['run']),
new AssignableMethodsFeature(),
]
async run (values) {

View File

@ -17,7 +17,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
const { get_user, get_app } = require("../../helpers");
const { AssignableMethodsTrait } = require("../../traits/AssignableMethodsTrait");
const { AssignableMethodsFeature } = require("../../traits/AssignableMethodsFeature");
const { Context } = require("../../util/context");
const BaseService = require("../BaseService");
const { DB_WRITE } = require("../database/consts");

View File

@ -20,7 +20,7 @@ const { AdvancedBase } = require("@heyputer/puter-js-common");
const APIError = require("../../api/APIError");
const { Context } = require("../../util/context");
const BaseService = require("../BaseService");
const { SyncTrait } = require("../../traits/SyncTrait");
const { SyncFeature } = require("../../traits/SyncFeature");
const { DB_WRITE } = require("../database/consts");
const ts_to_sql = (ts) => Math.floor(ts / 1000);
@ -31,8 +31,8 @@ class RateLimitService extends BaseService {
kv: globalThis.kv,
}
static TRAITS = [
new SyncTrait([
static FEATURES = [
new SyncFeature([
'check_and_increment',
]),
]

View File

@ -16,7 +16,7 @@
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
class AssignableMethodsTrait {
class AssignableMethodsFeature {
install_in_instance (instance) {
const methods = instance._get_merged_static_object('METHODS');
@ -27,5 +27,5 @@ class AssignableMethodsTrait {
}
module.exports = {
AssignableMethodsTrait
AssignableMethodsFeature
};

View File

@ -16,18 +16,18 @@
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
class AsyncProviderTrait {
class AsyncProviderFeature {
install_in_instance (instance) {
instance.valueListeners_ = {};
instance.valueFactories_ = {};
instance.values_ = {};
instance.rejections_ = {};
instance.provideValue = AsyncProviderTrait.prototype.provideValue;
instance.rejectValue = AsyncProviderTrait.prototype.rejectValue;
instance.awaitValue = AsyncProviderTrait.prototype.awaitValue;
instance.onValue = AsyncProviderTrait.prototype.onValue;
instance.setFactory = AsyncProviderTrait.prototype.setFactory;
instance.provideValue = AsyncProviderFeature.prototype.provideValue;
instance.rejectValue = AsyncProviderFeature.prototype.rejectValue;
instance.awaitValue = AsyncProviderFeature.prototype.awaitValue;
instance.onValue = AsyncProviderFeature.prototype.onValue;
instance.setFactory = AsyncProviderFeature.prototype.setFactory;
}
provideValue (key, value) {
@ -116,5 +116,5 @@ class AsyncProviderTrait {
}
module.exports = {
AsyncProviderTrait
AsyncProviderFeature
};

View File

@ -18,7 +18,7 @@
*/
const { Context } = require("../util/context");
class ContextAwareTrait {
class ContextAwareFeature {
install_in_instance (instance) {
instance.context = Context.get();
instance.x = instance.context;
@ -26,5 +26,5 @@ class ContextAwareTrait {
}
module.exports = {
ContextAwareTrait,
ContextAwareFeature,
};

View File

@ -18,7 +18,7 @@
*/
const { Context } = require("../util/context");
class OtelTrait {
class OtelFeature {
constructor (method_include_list) {
this.method_include_list = method_include_list;
}
@ -44,7 +44,7 @@ class OtelTrait {
}
}
class SyncOtelTrait {
class SyncOtelFeature {
constructor (method_include_list) {
this.method_include_list = method_include_list;
}
@ -72,5 +72,5 @@ class SyncOtelTrait {
}
module.exports = {
OtelTrait
OtelFeature
};

View File

@ -18,7 +18,7 @@
*/
const { Lock } = require("../util/promise");
class SyncTrait {
class SyncFeature {
constructor (method_include_list) {
this.method_include_list = method_include_list;
}
@ -37,5 +37,5 @@ class SyncTrait {
}
module.exports = {
SyncTrait,
SyncFeature,
};

View File

@ -16,7 +16,7 @@
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
class WeakConstructorTrait {
class WeakConstructorFeature {
install_in_instance(instance, { parameters }) {
for ( const key in parameters ) {
instance[key] = parameters[key];
@ -25,5 +25,5 @@ class WeakConstructorTrait {
}
module.exports = {
WeakConstructorTrait,
WeakConstructorFeature,
};

View File

@ -19,12 +19,12 @@
// This doesn't go in ./bases because it logically depends on
// both ./bases and ./traits, and ./traits depends on ./bases.
const { TraitBase } = require("./bases/TraitBase");
const { FeatureBase } = require("./bases/FeatureBase");
class AdvancedBase extends TraitBase {
static TRAITS = [
require('./traits/NodeModuleDITrait'),
require('./traits/PropertiesTrait'),
class AdvancedBase extends FeatureBase {
static FEATURES = [
require('./features/NodeModuleDIFeature'),
require('./features/PropertiesFeature'),
]
}

View File

@ -18,11 +18,11 @@
*/
const { BasicBase } = require("./BasicBase");
class TraitBase extends BasicBase {
class FeatureBase extends BasicBase {
constructor (parameters, ...a) {
super(parameters, ...a);
for ( const trait of this.traits ) {
trait.install_in_instance(
for ( const feature of this.features ) {
feature.install_in_instance(
this,
{
parameters: parameters || {},
@ -31,11 +31,11 @@ class TraitBase extends BasicBase {
}
}
get traits () {
return this._get_merged_static_array('TRAITS');
get features () {
return this._get_merged_static_array('FEATURES');
}
}
module.exports = {
TraitBase,
FeatureBase,
};

View File

@ -45,7 +45,7 @@ module.exports = {
}
instance.modules = modules;
// This "require" function can shadow the real one so
// that editor tools are aware of the modules that
// are being used.